Como: Extrair o dia da semana de uma data específica
O .NET facilita a verificação da posição numérica do dia da semana em uma determinada data e a exibição do nome do dia localizado em uma determinada data. O valor enumerado que indica o dia da semana correspondente a uma determinada data está disponível na propriedade DayOfWeek ou DayOfWeek. Em contrapartida, para recuperar o nome do dia da semana é necessário realizar uma operação de formatação que pode ser executada com a chamada de um método de formatação, como o método ToString
ou String.Format de valor de data e hora. Este tópico mostra como executar essas operações de formatação.
Extrair um número que indique o dia da semana
Use o método estático DateTime.Parse ou DateTimeOffset.Parse para converter a representação de cadeia de caracteres de uma data em um valor DateTimeou DateTimeOffset.
Use a propriedade DateTime.DayOfWeek ou DateTimeOffset.DayOfWeek para recuperar um valor de DayOfWeek que indica o dia da semana.
Se necessário, execute coerção (no C#) ou converta (no Visual Basic) o valor de DayOfWeek para um número inteiro.
O exemplo a seguir mostra um inteiro que representa o dia da semana de uma determinada data.
using System;
public class Example
{
public static void Main()
{
DateTime dateValue = new DateTime(2008, 6, 11);
Console.WriteLine((int) dateValue.DayOfWeek);
}
}
// The example displays the following output:
// 3
Module Example
Public Sub Main()
Dim dateValue As Date = #6/11/2008#
Console.WriteLine(dateValue.DayOfWeek)
End Sub
End Module
' The example displays the following output:
' 3
Extrair o nome abreviado do dia da semana
Use o método estático DateTime.Parse ou DateTimeOffset.Parse para converter a representação de cadeia de caracteres de uma data em um valor DateTimeou DateTimeOffset.
Você pode extrair o nome de dia da semana abreviado da cultura atual ou de uma cultura específica:
Para extrair o nome de dia da semana abreviado da cultura atual, chame o método de valor de data e hora DateTime.ToString(String) ou DateTimeOffset.ToString(String) de instância e informe a cadeia de caracteres
ddd
como o parâmetroformat
. O exemplo a seguir ilustra a chamada para o método ToString(String):using System; public class Example { public static void Main() { DateTime dateValue = new DateTime(2008, 6, 11); Console.WriteLine(dateValue.ToString("ddd")); } } // The example displays the following output: // Wed
Module Example Public Sub Main() Dim dateValue As Date = #6/11/2008# Console.WriteLine(dateValue.ToString("ddd")) End Sub End Module ' The example displays the following output: ' Wed
Para extrair o nome abreviado do dia da semana de uma cultura específica, chame o método de instância DateTime.ToString(String, IFormatProvider) ou DateTimeOffset.ToString(String, IFormatProvider) do valor de data e hora. Informe a cadeia de caracteres
ddd
como o parâmetroformat
. Apresente um objeto CultureInfo ou DateTimeFormatInfo que representa a cultura cujo nome de dia da semana deve ser recuperado como parâmetroprovider
. O código a seguir mostra um chamada ao método ToString(String, IFormatProvider) usando um objeto CultureInfo que representa a cultura fr-FR:using System; using System.Globalization; public class Example { public static void Main() { DateTime dateValue = new DateTime(2008, 6, 11); Console.WriteLine(dateValue.ToString("ddd", new CultureInfo("fr-FR"))); } } // The example displays the following output: // mer.
Imports System.Globalization Module Example Public Sub Main() Dim dateValue As Date = #6/11/2008# Console.WriteLine(dateValue.ToString("ddd", New CultureInfo("fr-FR"))) End Sub End Module ' The example displays the following output: ' mer.
Extrair o nome completo do dia da semana
Use o método estático DateTime.Parse ou DateTimeOffset.Parse para converter a representação de cadeia de caracteres de uma data em um valor DateTimeou DateTimeOffset.
Você pode extrair o nome completo de dia da semana da cultura atual ou de uma cultura específica:
Para extrair o nome de dia da semana da cultura atual, chame o método de valor de data e hora DateTime.ToString(String) ou DateTimeOffset.ToString(String) de instância e informe a cadeia de caracteres
dddd
como o parâmetroformat
. O exemplo a seguir ilustra a chamada para o método ToString(String):using System; public class Example { public static void Main() { DateTime dateValue = new DateTime(2008, 6, 11); Console.WriteLine(dateValue.ToString("dddd")); } } // The example displays the following output: // Wednesday
Module Example Public Sub Main() Dim dateValue As Date = #6/11/2008# Console.WriteLine(dateValue.ToString("dddd")) End Sub End Module ' The example displays the following output: ' Wednesday
Para extrair o nome do dia da semana de uma cultura específica, chame o método de instância DateTime.ToString(String, IFormatProvider) ou DateTimeOffset.ToString(String, IFormatProvider) do valor de data e hora. Informe a cadeia de caracteres
dddd
como o parâmetroformat
. Apresente um objeto CultureInfo ou DateTimeFormatInfo que representa a cultura cujo nome de dia da semana deve ser recuperado como parâmetroprovider
. O código a seguir ilustra um chamada ao método ToString(String, IFormatProvider) usando um objeto CultureInfo que representa a cultura es-ES:using System; using System.Globalization; public class Example { public static void Main() { DateTime dateValue = new DateTime(2008, 6, 11); Console.WriteLine(dateValue.ToString("dddd", new CultureInfo("es-ES"))); } } // The example displays the following output: // miércoles.
Imports System.Globalization Module Example Public Sub Main() Dim dateValue As Date = #6/11/2008# Console.WriteLine(dateValue.ToString("dddd", _ New CultureInfo("es-ES"))) End Sub End Module ' The example displays the following output: ' miércoles.
Exemplo
O exemplo a seguir ilustra chamadas para as propriedades DateTime.DayOfWeek e DateTimeOffset.DayOfWeek para recuperar o número que representa o dia da semana para uma data específica. Ele também inclui chamadas para os métodos DateTime.ToString e DateTimeOffset.ToString para extrair o nome abreviado do dia da semana e o nome completo do dia da semana.
using System;
using System.Globalization;
public class Example
{
public static void Main()
{
string dateString = "6/11/2007";
DateTime dateValue;
DateTimeOffset dateOffsetValue;
try
{
DateTimeFormatInfo dateTimeFormats;
// Convert date representation to a date value
dateValue = DateTime.Parse(dateString, CultureInfo.InvariantCulture);
dateOffsetValue = new DateTimeOffset(dateValue,
TimeZoneInfo.Local.GetUtcOffset(dateValue));
// Convert date representation to a number indicating the day of week
Console.WriteLine((int) dateValue.DayOfWeek);
Console.WriteLine((int) dateOffsetValue.DayOfWeek);
// Display abbreviated weekday name using current culture
Console.WriteLine(dateValue.ToString("ddd"));
Console.WriteLine(dateOffsetValue.ToString("ddd"));
// Display full weekday name using current culture
Console.WriteLine(dateValue.ToString("dddd"));
Console.WriteLine(dateOffsetValue.ToString("dddd"));
// Display abbreviated weekday name for de-DE culture
Console.WriteLine(dateValue.ToString("ddd", new CultureInfo("de-DE")));
Console.WriteLine(dateOffsetValue.ToString("ddd",
new CultureInfo("de-DE")));
// Display abbreviated weekday name with de-DE DateTimeFormatInfo object
dateTimeFormats = new CultureInfo("de-DE").DateTimeFormat;
Console.WriteLine(dateValue.ToString("ddd", dateTimeFormats));
Console.WriteLine(dateOffsetValue.ToString("ddd", dateTimeFormats));
// Display full weekday name for fr-FR culture
Console.WriteLine(dateValue.ToString("ddd", new CultureInfo("fr-FR")));
Console.WriteLine(dateOffsetValue.ToString("ddd",
new CultureInfo("fr-FR")));
// Display abbreviated weekday name with fr-FR DateTimeFormatInfo object
dateTimeFormats = new CultureInfo("fr-FR").DateTimeFormat;
Console.WriteLine(dateValue.ToString("dddd", dateTimeFormats));
Console.WriteLine(dateOffsetValue.ToString("dddd", dateTimeFormats));
}
catch (FormatException)
{
Console.WriteLine("Unable to convert {0} to a date.", dateString);
}
}
}
// The example displays the following output:
// 1
// 1
// Mon
// Mon
// Monday
// Monday
// Mo
// Mo
// Mo
// Mo
// lun.
// lun.
// lundi
// lundi
Imports System.Globalization
Module Example
Public Sub Main()
Dim dateString As String = "6/11/2007"
Dim dateValue As Date
Dim dateOffsetValue As DateTimeOffset
Try
Dim dateTimeFormats As DateTimeFormatInfo
' Convert date representation to a date value
dateValue = Date.Parse(dateString, CultureInfo.InvariantCulture)
dateOffsetValue = New DateTimeOffset(dateValue, _
TimeZoneInfo.Local.GetUtcOffset(dateValue))
' Convert date representation to a number indicating the day of week
Console.WriteLine(dateValue.DayOfWeek)
Console.WriteLine(dateOffsetValue.DayOfWeek)
' Display abbreviated weekday name using current culture
Console.WriteLine(dateValue.ToString("ddd"))
Console.WriteLine(dateOffsetValue.ToString("ddd"))
' Display full weekday name using current culture
Console.WriteLine(dateValue.ToString("dddd"))
Console.WriteLine(dateOffsetValue.ToString("dddd"))
' Display abbreviated weekday name for de-DE culture
Console.WriteLine(dateValue.ToString("ddd", New CultureInfo("de-DE")))
Console.WriteLine(dateOffsetValue.ToString("ddd", _
New CultureInfo("de-DE")))
' Display abbreviated weekday name with de-DE DateTimeFormatInfo object
dateTimeFormats = New CultureInfo("de-DE").DateTimeFormat
Console.WriteLine(dateValue.ToString("ddd", dateTimeFormats))
Console.WriteLine(dateOffsetValue.ToString("ddd", dateTimeFormats))
' Display full weekday name for fr-FR culture
Console.WriteLine(dateValue.ToString("ddd", New CultureInfo("fr-FR")))
Console.WriteLine(dateOffsetValue.ToString("ddd", _
New CultureInfo("fr-FR")))
' Display abbreviated weekday name with fr-FR DateTimeFormatInfo object
dateTimeFormats = New CultureInfo("fr-FR").DateTimeFormat
Console.WriteLine(dateValue.ToString("dddd", dateTimeFormats))
Console.WriteLine(dateOffsetValue.ToString("dddd", dateTimeFormats))
Catch e As FormatException
Console.WriteLine("Unable to convert {0} to a date.", dateString)
End Try
End Sub
End Module
' The example displays the following output to the console:
' 1
' 1
' Mon
' Mon
' Monday
' Monday
' Mo
' Mo
' Mo
' Mo
' lun.
' lun.
' lundi
' lundi
As linguagens individuais podem contar com funcionalidades que duplicam ou complementam a funcionalidade oferecida pelo .NET. Por exemplo, o Visual Basic tem duas funções desse tipo:
Weekday
, que retorna um número que indica o dia da semana de uma determinada data. Ele leva em consideração que o primeiro dia da semana tem valor ordinal um, enquanto a propriedade DateTime.DayOfWeek considera o valor ordinal desse dia como zero.WeekdayName
, que retorna o nome da semana na cultura atual e que corresponde ao número de um determinado dia da semana.
O exemplo a seguir ilustra o uso das funções do Visual Basic Weekday
e WeekdayName
:
Imports System.Globalization
Imports System.Threading
Module Example
Public Sub Main()
Dim dateValue As Date = #6/11/2008#
' Get weekday number using Visual Basic Weekday function
Console.WriteLine(Weekday(dateValue)) ' Displays 4
' Compare with .NET DateTime.DayOfWeek property
Console.WriteLine(dateValue.DayOfWeek) ' Displays 3
' Get weekday name using Weekday and WeekdayName functions
Console.WriteLine(WeekdayName(Weekday(dateValue))) ' Displays Wednesday
' Change culture to de-DE
Dim originalCulture As CultureInfo = Thread.CurrentThread.CurrentCulture
Thread.CurrentThread.CurrentCulture = New CultureInfo("de-DE")
' Get weekday name using Weekday and WeekdayName functions
Console.WriteLine(WeekdayName(Weekday(dateValue))) ' Displays Donnerstag
' Restore original culture
Thread.CurrentThread.CurrentCulture = originalCulture
End Sub
End Module
Você também pode usar o valor retornado pela propriedade DateTime.DayOfWeek para recuperar o nome de dia da semana de uma determinada data. Isso requer apenas uma chamada ao método ToString no valor DayOfWeek retornado pela propriedade. No entanto, essa técnica não gera um nome de dia da semana localizado para a cultura atual, como mostra o exemplo a seguir:
using System;
using System.Globalization;
using System.Threading;
public class Example
{
public static void Main()
{
// Change current culture to fr-FR
CultureInfo originalCulture = Thread.CurrentThread.CurrentCulture;
Thread.CurrentThread.CurrentCulture = new CultureInfo("fr-FR");
DateTime dateValue = new DateTime(2008, 6, 11);
// Display the DayOfWeek string representation
Console.WriteLine(dateValue.DayOfWeek.ToString());
// Restore original current culture
Thread.CurrentThread.CurrentCulture = originalCulture;
}
}
// The example displays the following output:
// Wednesday
Imports System.Globalization
Imports System.Threading
Module Example
Public Sub Main()
' Change current culture to fr-FR
Dim originalCulture As CultureInfo = Thread.CurrentThread.CurrentCulture
Thread.CurrentThread.CurrentCulture = New CultureInfo("fr-FR")
Dim dateValue As Date = #6/11/2008#
' Display the DayOfWeek string representation
Console.WriteLine(dateValue.DayOfWeek.ToString())
' Restore original current culture
Thread.CurrentThread.CurrentCulture = originalCulture
End Sub
End Module
' The example displays the following output:
' Wednesday