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

Definizione

Definisce un fuso orario non trovato nel computer locale.Defines a time zone that is not found on the local computer.

Overload

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

Crea un fuso orario personalizzato con un identificatore specificato, un offset dall'ora UTC (Coordinated Universal Time), un nome visualizzato e un nome visualizzato dell'ora solare.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[])

Crea un fuso orario personalizzato con un identificatore specificato, un offset dall'ora UTC (Coordinated Universal Time), un nome visualizzato, un nome dell'ora solare, un nome dell'ora legale e regole di applicazione per l'ora legale.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)

Crea un fuso orario personalizzato con un identificatore specificato, un offset dall'ora UTC (Coordinated Universal Time), un nome visualizzato, un nome dell'ora solare, un nome dell'ora legale, regole di applicazione per l'ora legale e un valore che indica se l'oggetto restituito riflette o meno le informazioni sull'ora legale.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)

Crea un fuso orario personalizzato con un identificatore specificato, un offset dall'ora UTC (Coordinated Universal Time), un nome visualizzato e un nome visualizzato dell'ora solare.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

Parametri

id
String String String String

Identificatore del fuso orario.The time zone's identifier.

baseUtcOffset
TimeSpan TimeSpan TimeSpan TimeSpan

Oggetto che rappresenta la differenza di ora tra questo fuso orario e l'ora UTC (Coordinated Universal Time).An object that represents the time difference between this time zone and Coordinated Universal Time (UTC).

displayName
String String String String

Nome visualizzato del nuovo fuso orario.The display name of the new time zone.

standardDisplayName
String String String String

Nome dell'ora solare del nuovo fuso orario.The name of the new time zone's standard time.

Restituisce

Nuovo fuso orario.The new time zone.

Eccezioni

Il valore del parametro id è null.The id parameter is null.

Il parametro id è una stringa vuota ("").The id parameter is an empty string ("").

-oppure--or- Il parametro baseUtcOffset non rappresenta un numero intero di minuti.The baseUtcOffset parameter does not represent a whole number of minutes.

Il parametro baseUtcOffset è maggiore di 14 ore o minore di -14 ore.The baseUtcOffset parameter is greater than 14 hours or less than -14 hours.

Esempi

Nell'esempio seguente viene creato un fuso orario personalizzato per le aree Mawson e Holme dell'Antartide.The following example creates a custom time zone for the Mawson and Holme Bay regions of Antarctica. Viene quindi visualizzato il risultato della conversione dell'ora locale nell'ora del nuovo fuso orario.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)      

Commenti

Questo overload del metodo CreateCustomTimeZone(String, TimeSpan, String, String) è adatto per la creazione di un fuso orario senza modifiche, ovvero un fuso orario che non supporta l'ora legale.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). Per definire un fuso orario che includa modifiche per l'ora legale, usare il TimeZoneInfo.CreateCustomTimeZone TimeZoneInfo.CreateCustomTimeZone metodo o.To define a time zone that includes adjustments for daylight saving time, use either the TimeZoneInfo.CreateCustomTimeZone or the TimeZoneInfo.CreateCustomTimeZone method.

Nella tabella seguente viene illustrata la relazione tra i parametri forniti al TimeZoneInfo.CreateCustomTimeZone metodo e le proprietà TimeZoneInfo dell'oggetto restituiti dalla chiamata al metodo.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.

Parametro CreateCustomTimeZoneCreateCustomTimeZone parameter Proprietà TimeZoneInfoTimeZoneInfo property
id Id
baseUtcOffset BaseUtcOffset
displayName DisplayName
standardDisplayName StandardName

In genere, il nome dell'ora solare del fuso orario e il relativo identificatore sono gli stessi.Typically, the time zone's standard time name and its identifier are the same. Tuttavia, la lunghezza dell'identificatore del fuso orario non deve superare i 32 caratteri.However, the length of the time zone's identifier should not exceed 32 characters. La stringa passata al displayName parametro segue un formato abbastanza standard.The string passed to the displayName parameter follows a fairly standard format. La prima parte del nome visualizzato è l'offset di base del fuso orario rispetto all'ora UTC (Coordinated Universal Time), indicato dall'acronimo GMT (per l'ora di Greenwich), racchiuso tra parentesi.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. Questa operazione è seguita da una stringa che identifica il fuso orario stesso o una o più città, aree o paesi nel fuso orario o entrambi.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. Ad esempio:For example:

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

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[])

Crea un fuso orario personalizzato con un identificatore specificato, un offset dall'ora UTC (Coordinated Universal Time), un nome visualizzato, un nome dell'ora solare, un nome dell'ora legale e regole di applicazione per l'ora legale.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

Parametri

id
String String String String

Identificatore del fuso orario.The time zone's identifier.

baseUtcOffset
TimeSpan TimeSpan TimeSpan TimeSpan

Oggetto che rappresenta la differenza di ora tra questo fuso orario e l'ora UTC (Coordinated Universal Time).An object that represents the time difference between this time zone and Coordinated Universal Time (UTC).

displayName
String String String String

Nome visualizzato del nuovo fuso orario.The display name of the new time zone.

standardDisplayName
String String String String

Nome dell'ora solare del nuovo fuso orario.The new time zone's standard time name.

daylightDisplayName
String String String String

Nome dell'ora legale del nuovo fuso orario.The daylight saving time name of the new time zone.

adjustmentRules
TimeZoneInfo.AdjustmentRule[]

Matrice che aumenta l'offset UTC di base per un determinato periodo.An array that augments the base UTC offset for a particular period.

Restituisce

Oggetto TimeZoneInfo che rappresenta il nuovo fuso orario.A TimeZoneInfo object that represents the new time zone.

Eccezioni

Il valore del parametro id è null.The id parameter is null.

Il parametro id è una stringa vuota ("").The id parameter is an empty string ("").

-oppure--or- Il parametro baseUtcOffset non rappresenta un numero intero di minuti.The baseUtcOffset parameter does not represent a whole number of minutes.

Il parametro baseUtcOffset è maggiore di 14 ore o minore di -14 ore.The baseUtcOffset parameter is greater than 14 hours or less than -14 hours.

Le regole di regolazione specificate nel parametro adjustmentRules si sovrappongono.The adjustment rules specified in the adjustmentRules parameter overlap.

-oppure--or- Le regole di regolazione specificate nel parametro adjustmentRules non sono in ordine cronologico.The adjustment rules specified in the adjustmentRules parameter are not in chronological order.

-oppure--or- Uno o più elementi in adjustmentRules sono null.One or more elements in adjustmentRules are null.

-oppure--or- A una data possono essere applicate più regole di regolazione.A date can have multiple adjustment rules applied to it.

-oppure--or- La somma del parametro baseUtcOffset e del valore DaylightDelta di uno o più oggetti nella matrice adjustmentRules è maggiore di 14 ore o minore di -14 ore.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.

Esempi

Nell'esempio seguente viene creato un fuso orario personalizzato per la stazione Palmer e l'isola Anversa in Antartide.The following example creates a custom time zone for the Palmer station and Anvers Island in Antarctica. Converte quindi l'ora locale nell'ora del nuovo fuso orario e visualizza il risultato.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)

Commenti

Questo overload del metodo TimeZoneInfo.CreateCustomTimeZone è adatto per la creazione di un fuso orario che supporta l'ora legale.This overload of the TimeZoneInfo.CreateCustomTimeZone method is suitable for creating a time zone that supports daylight saving time. Per definire un fuso orario che non supporta l'ora legale, usare il TimeZoneInfo.CreateCustomTimeZone TimeZoneInfo.CreateCustomTimeZone metodo o.To define a time zone that does not support daylight saving time, use either the TimeZoneInfo.CreateCustomTimeZone or the TimeZoneInfo.CreateCustomTimeZone method.

Nella tabella seguente viene illustrata la relazione tra i parametri forniti al TimeZoneInfo.CreateCustomTimeZone metodo e i membri TimeZoneInfo dell'oggetto restituiti dalla chiamata al metodo.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.

Parametro CreateCustomTimeZoneCreateCustomTimeZone parameter Membro TimeZoneInfoTimeZoneInfo member
id Id
baseUtcOffset BaseUtcOffset
displayName DisplayName
standardDisplayName StandardName
daylightDisplayName DaylightName
adjustmentRules Matrice di System.TimeZoneInfo.AdjustmentRule oggetti restituiti GetAdjustmentRules dal metodo.An array of System.TimeZoneInfo.AdjustmentRule objects returned by the GetAdjustmentRules method.

In genere, il nome dell'ora solare del fuso orario e il relativo identificatore sono gli stessi.Typically, the time zone's standard time name and its identifier are the same. Tuttavia, la lunghezza dell'identificatore del fuso orario non deve superare i 32 caratteri.However, the length of the time zone's identifier should not exceed 32 characters. La stringa passata al displayName parametro segue un formato abbastanza standard.The string passed to the displayName parameter follows a fairly standard format. La prima parte del nome visualizzato è l'offset di base del fuso orario rispetto all'ora UTC (Coordinated Universal Time), indicato dall'acronimo GMT (per l'ora di Greenwich), racchiuso tra parentesi.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. Questa operazione è seguita da una stringa che identifica il fuso orario stesso o una o più città, aree o paesi nel fuso orario o entrambi.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. Ad esempio:For example:

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

Il baseUtcOffset parametro definisce l'offset del fuso orario personalizzato rispetto all'ora UTC (Coordinated Universal Time) per tutte le regole di rettifica del fuso orario.The baseUtcOffset parameter defines the custom time zone's offset from Coordinated Universal Time (UTC) for all of the time zone's adjustment rules. In altre parole, il TimeZoneInfo modello a oggetti presuppone che l'offset del fuso orario rispetto all'ora UTC sia costante per tutta la durata del fuso orario e esista indipendentemente dalle specifiche regole di rettifica.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. Per riflettere un fuso orario in cui è stato modificato l'offset rispetto a UTC, è necessario creare un nuovo oggetto fuso orario.To reflect a time zone that has changed its offset from UTC, you must create a new time zone object.

Per definire le regole di rettifica del fuso orario, effettuare le operazioni seguenti:A time zone's adjustment rules are defined by doing the following:

  1. Chiamare il CreateFloatingDateRule CreateFixedDateRule metodo o per definire il tempo di transizione iniziale e finale per ogni regola di regolazione.Calling either the CreateFloatingDateRule or the CreateFixedDateRule method to define the starting and ending transition time for each adjustment rule.

  2. Chiamata del CreateAdjustmentRule metodo per ogni regola di regolazione.Calling the CreateAdjustmentRule method for each adjustment rule.

  3. Assegnazione delle regole di rettifica a una matrice che può essere passata come adjustmentRules parametro.Assigning the adjustment rules to an array that can be passed as the adjustmentRules parameter.

Vedi anche

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)

Crea un fuso orario personalizzato con un identificatore specificato, un offset dall'ora UTC (Coordinated Universal Time), un nome visualizzato, un nome dell'ora solare, un nome dell'ora legale, regole di applicazione per l'ora legale e un valore che indica se l'oggetto restituito riflette o meno le informazioni sull'ora legale.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

Parametri

id
String String String String

Identificatore del fuso orario.The time zone's identifier.

baseUtcOffset
TimeSpan TimeSpan TimeSpan TimeSpan

Oggetto TimeSpan che rappresenta la differenza di ora tra questo fuso orario e l'ora UTC (Coordinated Universal Time).A TimeSpan object that represents the time difference between this time zone and Coordinated Universal Time (UTC).

displayName
String String String String

Nome visualizzato del nuovo fuso orario.The display name of the new time zone.

standardDisplayName
String String String String

Nome dell'ora solare del nuovo fuso orario.The standard time name of the new time zone.

daylightDisplayName
String String String String

Nome dell'ora legale del nuovo fuso orario.The daylight saving time name of the new time zone.

adjustmentRules
TimeZoneInfo.AdjustmentRule[]

Matrice di oggetti TimeZoneInfo.AdjustmentRule che aumentano l'offset UTC di base per un determinato periodo.An array of TimeZoneInfo.AdjustmentRule objects that augment the base UTC offset for a particular period.

disableDaylightSavingTime
Boolean Boolean Boolean Boolean

true per rimuovere le informazioni relative all'ora legale presenti in adjustmentRules con il nuovo oggetto; in caso contrario, false.true to discard any daylight saving time-related information present in adjustmentRules with the new object; otherwise, false.

Restituisce

Nuovo fuso orario.The new time zone. Se il parametro disableDaylightSavingTime è true, l'oggetto restituito non include dati sull'ora legale.If the disableDaylightSavingTime parameter is true, the returned object has no daylight saving time data.

Eccezioni

Il valore del parametro id è null.The id parameter is null.

Il parametro id è una stringa vuota ("").The id parameter is an empty string ("").

In alternativa-or- Il parametro baseUtcOffset non rappresenta un numero intero di minuti.The baseUtcOffset parameter does not represent a whole number of minutes.

Il parametro baseUtcOffset è maggiore di 14 ore o minore di -14 ore.The baseUtcOffset parameter is greater than 14 hours or less than -14 hours.

Le regole di regolazione specificate nel parametro adjustmentRules si sovrappongono.The adjustment rules specified in the adjustmentRules parameter overlap.

In alternativa-or- Le regole di regolazione specificate nel parametro adjustmentRules non sono in ordine cronologico.The adjustment rules specified in the adjustmentRules parameter are not in chronological order.

-oppure--or- Uno o più elementi in adjustmentRules sono null.One or more elements in adjustmentRules are null.

In alternativa-or- A una data possono essere applicate più regole di regolazione.A date can have multiple adjustment rules applied to it.

-oppure--or- La somma del parametro baseUtcOffset e del valore DaylightDelta di uno o più oggetti nella matrice adjustmentRules è maggiore di 14 ore o minore di -14 ore.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.

Esempi

Nell'esempio seguente viene creato un fuso orario personalizzato per la stazione Palmer e l'isola Anversa in Antartide.The following example creates a custom time zone for the Palmer station and Anvers Island in Antarctica. Imposta il disableDaylightSavingTime parametro nella chiamata TimeZoneInfo.CreateCustomTimeZone al metodo su true.It sets the disableDaylightSavingTime parameter in the call to the TimeZoneInfo.CreateCustomTimeZone method to true. Viene quindi visualizzato il nome dell'ora legale del nuovo fuso orario, se presente, e il numero di regole di rettifica per verificare che il nuovo fuso orario non disponga di informazioni sull'ora legale.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)

Commenti

È possibile utilizzare questo overload del TimeZoneInfo.CreateCustomTimeZone metodo per creare un fuso orario personalizzato il cui supporto per l'ora legale può essere determinato in base alle condizioni in fase di esecuzione.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.

Nella tabella seguente viene illustrata la relazione tra i parametri forniti al TimeZoneInfo.CreateCustomTimeZone metodo e i membri TimeZoneInfo dell'oggetto restituiti dalla chiamata al metodo.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.

Parametro CreateCustomTimeZoneCreateCustomTimeZone parameter Proprietà TimeZoneInfoTimeZoneInfo property
id Id
baseUtcOffset BaseUtcOffset
displayName DisplayName
standardDisplayName StandardName
daylightDisplayName DaylightNameSe disableDaylightSavingTime è false; String.Empty sedisableDaylightSavingTime è .trueDaylightName if disableDaylightSavingTime is false; String.Empty if disableDaylightSavingTime is true.
adjustmentRules Matrice TimeZoneInfo.AdjustmentRule di trueoggetti GetAdjustmentRules restituita dal metodo se disableDaylightSavingTime false disableDaylightSavingTime è; una matrice vuota restituita dal metodoseè.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 Non SupportsDaylightSavingTime.Not SupportsDaylightSavingTime.

In genere, il nome dell'ora solare del fuso orario e il relativo identificatore sono gli stessi.Typically, the time zone's standard time name and its identifier are the same. Tuttavia, la lunghezza dell'identificatore del fuso orario non deve superare i 32 caratteri.However, the length of the time zone's identifier should not exceed 32 characters. La stringa passata al displayName parametro segue un formato abbastanza standard.The string passed to the displayName parameter follows a fairly standard format. La prima parte del nome visualizzato è l'offset di base del fuso orario rispetto all'ora UTC (Coordinated Universal Time), indicato dall'acronimo GMT (per l'ora di Greenwich), racchiuso tra parentesi.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. Questa operazione è seguita da una stringa che identifica il fuso orario stesso o una o più città, aree o paesi nel fuso orario o entrambi.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. Ad esempio:For example:

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

Per definire le regole di rettifica del fuso orario, effettuare le operazioni seguenti:A time zone's adjustment rules are defined by doing the following:

  1. Chiamare il CreateFloatingDateRule CreateFixedDateRule metodo o per definire le regole di transizione di inizio e fine per ogni regola di regolazione.Calling either the CreateFloatingDateRule or the CreateFixedDateRule method to define the starting and ending transition rules for each adjustment rule.

  2. Chiamata del CreateAdjustmentRule metodo per ogni regola di regolazione.Calling the CreateAdjustmentRule method for each adjustment rule.

  3. Assegnazione delle regole di rettifica a una matrice che può essere passata come adjustmentRules parametro.Assigning the adjustment rules to an array that can be passed as the adjustmentRules parameter.

Se disableDaylightSavingTime il parametro falseè, l'operazione di questo TimeZoneInfo.CreateCustomTimeZone metodo è identica all'overload.If disableDaylightSavingTime parameter is false, the operation of this method is identical to the TimeZoneInfo.CreateCustomTimeZone overload. Se disableDaylightSavingTime DaylightName è true, l'oggetto restituito non include regole di rettifica e una proprietà il cui valore è una stringa vuota.If disableDaylightSavingTime is true, the returned object includes no adjustment rules and a DaylightName property whose value is an empty string.

Vedi anche

Si applica a