TimeZoneInfo.CreateCustomTimeZone TimeZoneInfo.CreateCustomTimeZone TimeZoneInfo.CreateCustomTimeZone TimeZoneInfo.CreateCustomTimeZone Method

Определение

Определяет часовой пояс, который не удалось найти на локальном компьютере.Defines a time zone that is not found on the local computer.

Перегрузки

CreateCustomTimeZone(String, TimeSpan, String, String) CreateCustomTimeZone(String, TimeSpan, String, String) CreateCustomTimeZone(String, TimeSpan, String, String) CreateCustomTimeZone(String, TimeSpan, String, String)

Создает пользовательский часовой пояс с указанным идентификатором, смещением от времени в формате UTC, отображаемым именем, а также отображаемым именем зимнего времени.Creates a custom time zone with a specified identifier, an offset from Coordinated Universal Time (UTC), a display name, and a standard time display name.

CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[]) CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[]) CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[]) CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[])

Создает пользовательский часовой пояс с указанным идентификатором, смещением от времени в формате UTC, отображаемым именем, именем зимнего времени, именем летнего времени и правилами коррекции для летнего времени.Creates a custom time zone with a specified identifier, an offset from Coordinated Universal Time (UTC), a display name, a standard time name, a daylight saving time name, and daylight saving time rules.

CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[], Boolean) CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[], Boolean) CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[], Boolean) CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[], Boolean)

Создает пользовательский часовой пояс с указанным идентификатором, смещением от времени в формате UTC, отображаемым именем, именем зимнего времени, именем летнего времени, правилами коррекции для летнего времени и значением, позволяющим определить, отражает ли возвращаемый объект сведения о летнем времени.Creates a custom time zone with a specified identifier, an offset from Coordinated Universal Time (UTC), a display name, a standard time name, a daylight saving time name, daylight saving time rules, and a value that indicates whether the returned object reflects daylight saving time information.

CreateCustomTimeZone(String, TimeSpan, String, String) CreateCustomTimeZone(String, TimeSpan, String, String) CreateCustomTimeZone(String, TimeSpan, String, String) CreateCustomTimeZone(String, TimeSpan, String, String)

Создает пользовательский часовой пояс с указанным идентификатором, смещением от времени в формате UTC, отображаемым именем, а также отображаемым именем зимнего времени.Creates a custom time zone with a specified identifier, an offset from Coordinated Universal Time (UTC), a display name, and a standard time display name.

public:
 static TimeZoneInfo ^ CreateCustomTimeZone(System::String ^ id, TimeSpan baseUtcOffset, System::String ^ displayName, System::String ^ standardDisplayName);
public static TimeZoneInfo CreateCustomTimeZone (string id, TimeSpan baseUtcOffset, string displayName, string standardDisplayName);
static member CreateCustomTimeZone : string * TimeSpan * string * string -> TimeZoneInfo
Public Shared Function CreateCustomTimeZone (id As String, baseUtcOffset As TimeSpan, displayName As String, standardDisplayName As String) As TimeZoneInfo

Параметры

id
String String String String

Идентификатор часового пояса.The time zone's identifier.

baseUtcOffset
TimeSpan TimeSpan TimeSpan TimeSpan

Объект, представляющий разность между значением времени в данном часовом поясе и временем в формате UTC.An object that represents the time difference between this time zone and Coordinated Universal Time (UTC).

displayName
String String String String

Отображаемое имя нового часового пояса.The display name of the new time zone.

standardDisplayName
String String String String

Имя зимнего времени нового часового пояса.The name of the new time zone's standard time.

Возвраты

Новый часовой пояс.The new time zone.

Исключения

Параметр id имеет значение null.The id parameter is null.

Параметр id представляет собой пустую строку ("").The id parameter is an empty string ("").

- или --or- Параметр baseUtcOffset не представляет целое число минут.The baseUtcOffset parameter does not represent a whole number of minutes.

Значение параметра baseUtcOffset больше 14 часов или меньше –14 часов.The baseUtcOffset parameter is greater than 14 hours or less than -14 hours.

Примеры

В следующем примере создается пользовательский часовой пояс для регионов Моусон и холм отсека Антарктида.The following example creates a custom time zone for the Mawson and Holme Bay regions of Antarctica. Затем он отображает результат преобразования местного времени во время в новом часовом поясе.It then displays the result of converting the local time to the time in the new time zone.

string displayName = "(GMT+06:00) Antarctica/Mawson Time";
string standardName = "Mawson Time"; 
TimeSpan offset = new TimeSpan(06, 00, 00);
TimeZoneInfo mawson = TimeZoneInfo.CreateCustomTimeZone(standardName, offset, displayName, standardName);
Console.WriteLine("The current time is {0} {1}", 
                  TimeZoneInfo.ConvertTime(DateTime.Now, TimeZoneInfo.Local, mawson),
                  mawson.StandardName);      
Dim displayName As String = "(GMT+06:00) Antarctica/Mawson Time"
Dim standardName As String = "Mawson Time" 
Dim offset As TimeSpan = New TimeSpan(06, 00, 00)
Dim mawson As TimeZoneInfo = TimeZoneInfo.CreateCustomTimeZone(standardName, offset, displayName, standardName)
Console.WriteLine("The current time is {0} {1}", _ 
                  TimeZoneInfo.ConvertTime(Date.Now, TimeZoneInfo.Local, mawson), _
                  mawson.StandardName)      

Комментарии

Эта перегрузка CreateCustomTimeZone(String, TimeSpan, String, String) метода подходит для создания часового пояса, не имеющего корректировок (то есть часового пояса, не поддерживающего летнее время).This overload of the CreateCustomTimeZone(String, TimeSpan, String, String) method is suitable for creating a time zone that has no adjustments (that is, a time zone that does not support daylight saving time). Чтобы определить часовой пояс, включающий корректировки перехода на летнее время, используйте TimeZoneInfo.CreateCustomTimeZone TimeZoneInfo.CreateCustomTimeZone метод или.To define a time zone that includes adjustments for daylight saving time, use either the TimeZoneInfo.CreateCustomTimeZone or the TimeZoneInfo.CreateCustomTimeZone method.

В следующей таблице показана связь между параметрами, предоставляемыми TimeZoneInfo.CreateCustomTimeZone методу, и свойствами TimeZoneInfo объекта, возвращаемых вызовом метода.The following table shows the relationship between the parameters that are provided to the TimeZoneInfo.CreateCustomTimeZone method and the properties of the TimeZoneInfo object that are returned by the method call.

Креатекустомтимезоне, параметрCreateCustomTimeZone parameter TimeZoneInfo, свойствоTimeZoneInfo property
id Id
baseUtcOffset BaseUtcOffset
displayName DisplayName
standardDisplayName StandardName

Как правило, имя стандартного времени часового пояса и его идентификатор одинаковы.Typically, the time zone's standard time name and its identifier are the same. Однако длина идентификатора часового пояса не должна превышать 32 символов.However, the length of the time zone's identifier should not exceed 32 characters. Строка, передаваемая в displayName параметр, имеет довольно стандартный формат.The string passed to the displayName parameter follows a fairly standard format. Первая часть отображаемого имени — это базовое смещение часового пояса относительно универсального всемирного времени, которое обозначается аббревиатурой GMT (для среднего времени по Гринвичу), заключенной в круглые скобки.The first portion of the display name is the time zone's base offset from Coordinated Universal Time, which is indicated by the acronym GMT (for Greenwich Mean Time), enclosed in parentheses. За ним следует строка, идентифицирующая часовой пояс, или один или несколько городов, регионов или стран часового пояса.This is followed by a string that identifies the time zone itself, or one or more of the cities, regions, or countries in the time zone, or both. Например:For example:

(GMT+02:00) Athens, Beirut, Istanbul, Minsk  
(GMT-02:00) Mid-Atlantic  
(GMT-07:00) Mountain Time (US & Canada)  
Дополнительно

CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[]) CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[]) CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[]) CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[])

Создает пользовательский часовой пояс с указанным идентификатором, смещением от времени в формате UTC, отображаемым именем, именем зимнего времени, именем летнего времени и правилами коррекции для летнего времени.Creates a custom time zone with a specified identifier, an offset from Coordinated Universal Time (UTC), a display name, a standard time name, a daylight saving time name, and daylight saving time rules.

public:
 static TimeZoneInfo ^ CreateCustomTimeZone(System::String ^ id, TimeSpan baseUtcOffset, System::String ^ displayName, System::String ^ standardDisplayName, System::String ^ daylightDisplayName, cli::array <TimeZoneInfo::AdjustmentRule ^> ^ adjustmentRules);
public static TimeZoneInfo CreateCustomTimeZone (string id, TimeSpan baseUtcOffset, string displayName, string standardDisplayName, string daylightDisplayName, TimeZoneInfo.AdjustmentRule[] adjustmentRules);
static member CreateCustomTimeZone : string * TimeSpan * string * string * string * TimeZoneInfo.AdjustmentRule[] -> TimeZoneInfo
Public Shared Function CreateCustomTimeZone (id As String, baseUtcOffset As TimeSpan, displayName As String, standardDisplayName As String, daylightDisplayName As String, adjustmentRules As TimeZoneInfo.AdjustmentRule()) As TimeZoneInfo

Параметры

id
String String String String

Идентификатор часового пояса.The time zone's identifier.

baseUtcOffset
TimeSpan TimeSpan TimeSpan TimeSpan

Объект, представляющий разность между значением времени в данном часовом поясе и временем в формате UTC.An object that represents the time difference between this time zone and Coordinated Universal Time (UTC).

displayName
String String String String

Отображаемое имя нового часового пояса.The display name of the new time zone.

standardDisplayName
String String String String

Имя зимнего времени нового часового пояса.The new time zone's standard time name.

daylightDisplayName
String String String String

Имя летнего времени нового часового пояса.The daylight saving time name of the new time zone.

adjustmentRules
TimeZoneInfo.AdjustmentRule[]

Массив, который прибавляет базовое смещение относительно UTC для определенного периода.An array that augments the base UTC offset for a particular period.

Возвраты

Объект TimeZoneInfo, представляющий новый часовой пояс.A TimeZoneInfo object that represents the new time zone.

Исключения

Параметр id имеет значение null.The id parameter is null.

Параметр id представляет собой пустую строку ("").The id parameter is an empty string ("").

- или --or- Параметр baseUtcOffset не представляет целое число минут.The baseUtcOffset parameter does not represent a whole number of minutes.

Значение параметра baseUtcOffset больше 14 часов или меньше –14 часов.The baseUtcOffset parameter is greater than 14 hours or less than -14 hours.

Правила коррекции, заданные в параметре adjustmentRules, перекрываются.The adjustment rules specified in the adjustmentRules parameter overlap.

- или --or- Последовательность правил коррекции, заданных в параметре adjustmentRules, не является хронологической.The adjustment rules specified in the adjustmentRules parameter are not in chronological order.

-или--or- Один или несколько элементов в adjustmentRules имеют значение null.One or more elements in adjustmentRules are null.

- или --or- К одной дате может быть применено несколько правил коррекции.A date can have multiple adjustment rules applied to it.

-или--or- Сумма параметра baseUtcOffset и значения свойства DaylightDelta одного или нескольких объектов в массиве adjustmentRules больше 14 часов или меньше –14 часов.The sum of the baseUtcOffset parameter and the DaylightDelta value of one or more objects in the adjustmentRules array is greater than 14 hours or less than -14 hours.

Примеры

В следующем примере создается пользовательский часовой пояс для станции Палмер и остров Анверс в Антарктида.The following example creates a custom time zone for the Palmer station and Anvers Island in Antarctica. Затем оно преобразует местное время во время в новом часовом поясе и отображает результат.It then converts the local time to the time in the new time zone and displays the result.

// Define transition times to/from DST
TimeZoneInfo.TransitionTime startTransition, endTransition;
startTransition = TimeZoneInfo.TransitionTime.CreateFloatingDateRule(new DateTime(1, 1, 1, 4, 0, 0), 
                                                                  10, 2, DayOfWeek.Sunday); 
endTransition = TimeZoneInfo.TransitionTime.CreateFloatingDateRule(new DateTime(1, 1, 1, 3, 0, 0), 
                                                                3, 2, DayOfWeek.Sunday);
// Define adjustment rule
TimeSpan delta = new TimeSpan(1, 0, 0);
TimeZoneInfo.AdjustmentRule adjustment;
adjustment = TimeZoneInfo.AdjustmentRule.CreateAdjustmentRule(new DateTime(1999, 10, 1), DateTime.MaxValue.Date, delta, startTransition, endTransition);
// Create array for adjustment rules
TimeZoneInfo.AdjustmentRule[] adjustments = {adjustment};
// Define other custom time zone arguments
string displayName = "(GMT-04:00) Antarctica/Palmer Time";
string standardName = "Palmer Time";
string daylightName = "Palmer Daylight Time";
TimeSpan offset = new TimeSpan(-4, 0, 0);
TimeZoneInfo palmer = TimeZoneInfo.CreateCustomTimeZone(standardName, offset, displayName, standardName, daylightName, adjustments);
Console.WriteLine("The current time is {0} {1}",  
                  TimeZoneInfo.ConvertTime(DateTime.Now, TimeZoneInfo.Local, palmer), 
                  palmer.StandardName);
' Define transition times to/from DST
Dim startTransition As TimeZoneInfo.TransitionTime = TimeZoneInfo.TransitionTime.CreateFloatingDateRule(#04:00:00#, 10, 2, DayOfWeek.Sunday) 
Dim endTransition As TimeZoneInfo.TransitionTime = TimeZoneInfo.TransitionTime.CreateFloatingDateRule(#3:00:00#, 3, 2, DayOfWeek.Sunday)
' Define adjustment rule
Dim delta As TimeSpan = New TimeSpan(1, 0, 0)
Dim adjustment As TimeZoneInfo.AdjustmentRule = TimeZoneInfo.AdjustmentRule.CreateAdjustmentRule(#10/01/1999#, Date.MaxValue.Date, delta, startTransition, endTransition)
' Create array for adjustment rules
Dim adjustments() As TimeZoneInfo.AdjustmentRule = {adjustment}
' Define other custom time zone arguments
Dim DisplayName As String = "(GMT-04:00) Antarctica/Palmer Time"
Dim standardName As String = "Palmer Standard Time"
Dim daylightName As String = "Palmer Daylight Time"
Dim offset As TimeSpan = New TimeSpan(-4, 0, 0)
Dim palmer As TimeZoneInfo = TimeZoneInfo.CreateCustomTimeZone(standardName, offset, displayName, standardName, daylightName, adjustments)
Console.WriteLine("The current time is {0} {1}", _ 
                  TimeZoneInfo.ConvertTime(Date.Now, TimeZoneInfo.Local, palmer), _
                  palmer.StandardName)

Комментарии

Эта перегрузка TimeZoneInfo.CreateCustomTimeZone метода подходит для создания часового пояса, поддерживающего переход на летнее время.This overload of the TimeZoneInfo.CreateCustomTimeZone method is suitable for creating a time zone that supports daylight saving time. Чтобы определить часовой пояс, который не поддерживает переход на летнее время, используйте TimeZoneInfo.CreateCustomTimeZone TimeZoneInfo.CreateCustomTimeZone метод или.To define a time zone that does not support daylight saving time, use either the TimeZoneInfo.CreateCustomTimeZone or the TimeZoneInfo.CreateCustomTimeZone method.

В следующей таблице показана связь между параметрами, предоставленными TimeZoneInfo.CreateCustomTimeZone методу, и членам TimeZoneInfo объекта, возвращаемых вызовом метода.The following table shows the relationship between the parameters that are provided to the TimeZoneInfo.CreateCustomTimeZone method and the members of the TimeZoneInfo object that are returned by the method call.

Креатекустомтимезоне, параметрCreateCustomTimeZone parameter TimeZoneInfo, элементTimeZoneInfo member
id Id
baseUtcOffset BaseUtcOffset
displayName DisplayName
standardDisplayName StandardName
daylightDisplayName DaylightName
adjustmentRules Массив System.TimeZoneInfo.AdjustmentRule объектовGetAdjustmentRules , возвращаемых методом.An array of System.TimeZoneInfo.AdjustmentRule objects returned by the GetAdjustmentRules method.

Как правило, имя стандартного времени часового пояса и его идентификатор одинаковы.Typically, the time zone's standard time name and its identifier are the same. Однако длина идентификатора часового пояса не должна превышать 32 символов.However, the length of the time zone's identifier should not exceed 32 characters. Строка, передаваемая в displayName параметр, имеет довольно стандартный формат.The string passed to the displayName parameter follows a fairly standard format. Первая часть отображаемого имени — это базовое смещение часового пояса относительно универсального всемирного времени, которое обозначается аббревиатурой GMT (для среднего времени по Гринвичу), заключенной в круглые скобки.The first portion of the display name is the time zone's base offset from Coordinated Universal Time, which is indicated by the acronym GMT (for Greenwich Mean Time), enclosed in parentheses. За ним следует строка, идентифицирующая часовой пояс, или один или несколько городов, регионов или стран часового пояса.This is followed by a string that identifies the time zone itself, or one or more of the cities, regions, or countries in the time zone, or both. Например:For example:

(GMT+02:00) Athens, Beirut, Istanbul, Minsk  
(GMT-02:00) Mid-Atlantic  
(GMT-07:00) Mountain Time (US & Canada)  

baseUtcOffset Параметр определяет смещение пользовательского часового пояса относительно всеобщего скоординированного времени (UTC) для всех правил коррекции часового пояса.The baseUtcOffset parameter defines the custom time zone's offset from Coordinated Universal Time (UTC) for all of the time zone's adjustment rules. Иными словами, TimeZoneInfo объектная модель предполагает, что смещение часового пояса от времени UTC будет постоянным в течение жизненного цикла часового пояса и существует независимо от конкретных правил коррекции.In other words, the TimeZoneInfo object model assumes that the time zone's offset from UTC is constant throughout the life of the time zone, and exists independent of particular adjustment rules. Чтобы отразить часовой пояс, в котором изменилось смещение относительно времени в формате UTC, необходимо создать новый объект часового пояса.To reflect a time zone that has changed its offset from UTC, you must create a new time zone object.

Правила коррекции часового пояса определяются следующим образом.A time zone's adjustment rules are defined by doing the following:

  1. CreateFloatingDateRule Вызов методаCreateFixedDateRule или для определения начального и конечного времени перехода для каждого правила коррекции.Calling either the CreateFloatingDateRule or the CreateFixedDateRule method to define the starting and ending transition time for each adjustment rule.

  2. CreateAdjustmentRule Вызов метода для каждого правила коррекции.Calling the CreateAdjustmentRule method for each adjustment rule.

  3. Назначение правил коррекции массиву, который можно передать в качестве adjustmentRules параметра.Assigning the adjustment rules to an array that can be passed as the adjustmentRules parameter.

Дополнительно

CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[], Boolean) CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[], Boolean) CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[], Boolean) CreateCustomTimeZone(String, TimeSpan, String, String, String, TimeZoneInfo+AdjustmentRule[], Boolean)

Создает пользовательский часовой пояс с указанным идентификатором, смещением от времени в формате UTC, отображаемым именем, именем зимнего времени, именем летнего времени, правилами коррекции для летнего времени и значением, позволяющим определить, отражает ли возвращаемый объект сведения о летнем времени.Creates a custom time zone with a specified identifier, an offset from Coordinated Universal Time (UTC), a display name, a standard time name, a daylight saving time name, daylight saving time rules, and a value that indicates whether the returned object reflects daylight saving time information.

public:
 static TimeZoneInfo ^ CreateCustomTimeZone(System::String ^ id, TimeSpan baseUtcOffset, System::String ^ displayName, System::String ^ standardDisplayName, System::String ^ daylightDisplayName, cli::array <TimeZoneInfo::AdjustmentRule ^> ^ adjustmentRules, bool disableDaylightSavingTime);
public static TimeZoneInfo CreateCustomTimeZone (string id, TimeSpan baseUtcOffset, string displayName, string standardDisplayName, string daylightDisplayName, TimeZoneInfo.AdjustmentRule[] adjustmentRules, bool disableDaylightSavingTime);
static member CreateCustomTimeZone : string * TimeSpan * string * string * string * TimeZoneInfo.AdjustmentRule[] * bool -> TimeZoneInfo
Public Shared Function CreateCustomTimeZone (id As String, baseUtcOffset As TimeSpan, displayName As String, standardDisplayName As String, daylightDisplayName As String, adjustmentRules As TimeZoneInfo.AdjustmentRule(), disableDaylightSavingTime As Boolean) As TimeZoneInfo

Параметры

id
String String String String

Идентификатор часового пояса.The time zone's identifier.

baseUtcOffset
TimeSpan TimeSpan TimeSpan TimeSpan

Объект TimeSpan, представляющий разность между значением времени в данном часовом поясе и временем в формате UTC.A TimeSpan object that represents the time difference between this time zone and Coordinated Universal Time (UTC).

displayName
String String String String

Отображаемое имя нового часового пояса.The display name of the new time zone.

standardDisplayName
String String String String

Имя зимнего времени нового часового пояса.The standard time name of the new time zone.

daylightDisplayName
String String String String

Имя летнего времени нового часового пояса.The daylight saving time name of the new time zone.

adjustmentRules
TimeZoneInfo.AdjustmentRule[]

Массив объектов TimeZoneInfo.AdjustmentRule, которые прибавляют базовое смещение относительно UTC для определенного периода.An array of TimeZoneInfo.AdjustmentRule objects that augment the base UTC offset for a particular period.

disableDaylightSavingTime
Boolean Boolean Boolean Boolean

Значение true для сброса в новом объекте всех связанных с летним временем сведений, представленных в параметре adjustmentRules; в противном случае — false.true to discard any daylight saving time-related information present in adjustmentRules with the new object; otherwise, false.

Возвраты

Новый часовой пояс.The new time zone. Если значение параметра disableDaylightSavingTime равно true, в возвращаемом объекте отсутствуют данные о летнем времени.If the disableDaylightSavingTime parameter is true, the returned object has no daylight saving time data.

Исключения

Параметр id имеет значение null.The id parameter is null.

Параметр id представляет собой пустую строку ("").The id parameter is an empty string ("").

- или --or- Параметр baseUtcOffset не представляет целое число минут.The baseUtcOffset parameter does not represent a whole number of minutes.

Значение параметра baseUtcOffset больше 14 часов или меньше –14 часов.The baseUtcOffset parameter is greater than 14 hours or less than -14 hours.

Правила коррекции, заданные в параметре adjustmentRules, перекрываются.The adjustment rules specified in the adjustmentRules parameter overlap.

- или --or- Последовательность правил коррекции, заданных в параметре adjustmentRules, не является хронологической.The adjustment rules specified in the adjustmentRules parameter are not in chronological order.

- или --or- Один или несколько элементов в adjustmentRules имеют значение null.One or more elements in adjustmentRules are null.

- или --or- К одной дате может быть применено несколько правил коррекции.A date can have multiple adjustment rules applied to it.

-или--or- Сумма параметра baseUtcOffset и значения свойства DaylightDelta одного или нескольких объектов в массиве adjustmentRules больше 14 часов или меньше –14 часов.The sum of the baseUtcOffset parameter and the DaylightDelta value of one or more objects in the adjustmentRules array is greater than 14 hours or less than -14 hours.

Примеры

В следующем примере создается пользовательский часовой пояс для станции Палмер и остров Анверс в Антарктида.The following example creates a custom time zone for the Palmer station and Anvers Island in Antarctica. Он устанавливает disableDaylightSavingTime параметр в вызове TimeZoneInfo.CreateCustomTimeZone метода trueв значение.It sets the disableDaylightSavingTime parameter in the call to the TimeZoneInfo.CreateCustomTimeZone method to true. Затем он отображает имя летнего времени для нового часового пояса, если оно существует, и число правил коррекции для подтверждения того, что в новом часовом поясе нет информации о летнем времени.It then displays the new time zone's daylight saving time name, if one is present, and the number of adjustment rules to confirm that the new time zone has no daylight saving time information.

// Define transition times to/from DST
TimeZoneInfo.TransitionTime startTransition, endTransition;
startTransition = TimeZoneInfo.TransitionTime.CreateFloatingDateRule(new DateTime(1, 1, 1, 4, 0, 0),
                                                                  10, 2, DayOfWeek.Sunday); 
endTransition = TimeZoneInfo.TransitionTime.CreateFloatingDateRule(new DateTime(1, 1, 1,3, 0, 0), 
                                                                3, 2, DayOfWeek.Sunday);
// Define adjustment rule
TimeSpan delta = new TimeSpan(1, 0, 0);
TimeZoneInfo.AdjustmentRule adjustment = TimeZoneInfo.AdjustmentRule.CreateAdjustmentRule(new DateTime(1999, 10, 1), 
                                      DateTime.MaxValue.Date, delta, startTransition, endTransition);
// Create array for adjustment rules
TimeZoneInfo.AdjustmentRule[] adjustments = {adjustment};
// Define other custom time zone arguments
string displayName = "(GMT-04:00) Antarctica/Palmer Time";
string standardName = "Palmer Standard Time";
string daylightName = "Palmer Daylight Time";
TimeSpan offset = new TimeSpan(-4, 0, 0);
// Create custom time zone without copying DST information
TimeZoneInfo palmer = TimeZoneInfo.CreateCustomTimeZone(standardName, offset, displayName, standardName, 
                                                  daylightName, adjustments, true);
// Indicate whether new time zone//s adjustment rules are present
Console.WriteLine("{0} {1}has {2} adjustment rules.", 
                  palmer.StandardName, 
                  ! (string.IsNullOrEmpty(palmer.DaylightName)) ?  "(" + palmer.DaylightName + ") ": "" , 
                  palmer.GetAdjustmentRules().Length);
// Indicate whether new time zone supports DST
Console.WriteLine("{0} supports DST: {1}", palmer.StandardName, palmer.SupportsDaylightSavingTime);
' Define transition times to/from DST
Dim startTransition As TimeZoneInfo.TransitionTime = TimeZoneInfo.TransitionTime.CreateFloatingDateRule(#04:00:00#, 10, 2, DayOfWeek.Sunday) 
Dim endTransition As TimeZoneInfo.TransitionTime = TimeZoneInfo.TransitionTime.CreateFloatingDateRule(#3:00:00#, 3, 2, DayOfWeek.Sunday)
' Define adjustment rule
Dim delta As TimeSpan = New TimeSpan(1, 0, 0)
Dim adjustment As TimeZoneInfo.AdjustmentRule = TimeZoneInfo.AdjustmentRule.CreateAdjustmentRule(#10/01/1999#, Date.MaxValue.Date, delta, startTransition, endTransition)
' Create array for adjustment rules
Dim adjustments() As TimeZoneInfo.AdjustmentRule = {adjustment}
' Define other custom time zone arguments
Dim displayName As String = "(GMT-04:00) Antarctica/Palmer Time"
Dim standardName As String = "Palmer Standard Time"
Dim daylightName As String = "Palmer Daylight Time"
Dim offset As TimeSpan = New TimeSpan(-4, 0, 0)
Dim palmer As TimeZoneInfo = TimeZoneInfo.CreateCustomTimeZone(standardName, offset, displayName, standardName, daylightName, adjustments, True)
' Indicate whether new time zone's adjustment rules are present
Console.WriteLine("{0} {1}has {2} adjustment rules.", _
                  palmer.StandardName, _
                  IIf(Not String.IsNullOrEmpty(palmer.DaylightName), "(" & palmer.DaylightName & ") ", ""), _
                  palmer.GetAdjustmentRules().Length)
' Indicate whether new time zone supports DST
Console.WriteLine("{0} supports DST: {1}", palmer.StandardName, palmer.SupportsDaylightSavingTime)

Комментарии

Эту перегрузку TimeZoneInfo.CreateCustomTimeZone метода можно использовать для создания пользовательского часового пояса, поддержка которого может быть определена условиями во время выполнения.You can use this overload of the TimeZoneInfo.CreateCustomTimeZone method to create a custom time zone whose support for daylight saving time can be determined by conditions at run time.

В следующей таблице показана связь между параметрами, предоставленными TimeZoneInfo.CreateCustomTimeZone методу, и членам TimeZoneInfo объекта, возвращаемых вызовом метода.The following table shows the relationship between the parameters that are provided to the TimeZoneInfo.CreateCustomTimeZone method and the members of the TimeZoneInfo object that are returned by the method call.

Креатекустомтимезоне, параметрCreateCustomTimeZone parameter TimeZoneInfo, свойствоTimeZoneInfo property
id Id
baseUtcOffset BaseUtcOffset
displayName DisplayName
standardDisplayName StandardName
daylightDisplayName DaylightNameЕсли disableDaylightSavingTime имеет falseзначение; String.Empty если имеетdisableDaylightSavingTime значение .trueDaylightName if disableDaylightSavingTime is false; String.Empty if disableDaylightSavingTime is true.
adjustmentRules TimeZoneInfo.AdjustmentRule Массив disableDaylightSavingTime объектов, возвращаемых GetAdjustmentRules методом, если disableDaylightSavingTime false trueимеет значение; пустой массив, возвращаемый методом,еслиимеетзначение.GetAdjustmentRulesAn array of TimeZoneInfo.AdjustmentRule objects returned by the GetAdjustmentRules method if disableDaylightSavingTime is false; an empty array returned by the GetAdjustmentRules method if disableDaylightSavingTime is true.
disableDaylightSavingTime Нет SupportsDaylightSavingTime.Not SupportsDaylightSavingTime.

Как правило, имя стандартного времени часового пояса и его идентификатор одинаковы.Typically, the time zone's standard time name and its identifier are the same. Однако длина идентификатора часового пояса не должна превышать 32 символов.However, the length of the time zone's identifier should not exceed 32 characters. Строка, передаваемая в displayName параметр, имеет довольно стандартный формат.The string passed to the displayName parameter follows a fairly standard format. Первая часть отображаемого имени — это базовое смещение часового пояса относительно универсального всемирного времени, которое обозначается аббревиатурой GMT (для среднего времени по Гринвичу), заключенной в круглые скобки.The first portion of the display name is the time zone's base offset from Coordinated Universal Time, which is indicated by the acronym GMT (for Greenwich Mean Time), enclosed in parentheses. За ним следует строка, идентифицирующая часовой пояс, или один или несколько городов, регионов или стран часового пояса.This is followed by a string that identifies the time zone itself, or one or more of the cities, regions, or countries in the time zone, or both. Например:For example:

(GMT+02:00) Athens, Beirut, Istanbul, Minsk  
(GMT-02:00) Mid-Atlantic  
(GMT-07:00) Mountain Time (US & Canada)  

Правила коррекции часового пояса определяются следующим образом.A time zone's adjustment rules are defined by doing the following:

  1. CreateFloatingDateRule Вызов методаCreateFixedDateRule или для определения начального и конечного правил перехода для каждого правила коррекции.Calling either the CreateFloatingDateRule or the CreateFixedDateRule method to define the starting and ending transition rules for each adjustment rule.

  2. CreateAdjustmentRule Вызов метода для каждого правила коррекции.Calling the CreateAdjustmentRule method for each adjustment rule.

  3. Назначение правил коррекции массиву, который можно передать в качестве adjustmentRules параметра.Assigning the adjustment rules to an array that can be passed as the adjustmentRules parameter.

Если disableDaylightSavingTime параметр имеет falseзначение, операция этого TimeZoneInfo.CreateCustomTimeZone метода идентична перегрузке.If disableDaylightSavingTime parameter is false, the operation of this method is identical to the TimeZoneInfo.CreateCustomTimeZone overload. Если disableDaylightSavingTime параметр trueимеет значение, возвращаемый объект DaylightName не включает правила коррекции и свойство, значение которого является пустой строкой.If disableDaylightSavingTime is true, the returned object includes no adjustment rules and a DaylightName property whose value is an empty string.

Дополнительно

Применяется к