Leer en inglés

Compartir a través de


TimeZoneInfo.ToSerializedString Método

Definición

Convierte el objeto TimeZoneInfo actual en una cadena serializada.

C#
public string ToSerializedString();

Devoluciones

Una cadena que representa el objeto TimeZoneInfo actual.

Ejemplos

En el ejemplo siguiente se intenta recuperar la zona horaria Antártida/Polo Sur del sistema local. Si se produce un error, el código intenta recuperar información sobre la zona horaria de un archivo de texto en el directorio de la aplicación. Si se produce un error en este intento, el código crea la zona horaria y escribe información sobre ella en el archivo de texto.

C#
private TimeZoneInfo InitializeTimeZone()
{
   TimeZoneInfo southPole = null;
   // Determine if South Pole time zone is defined in system
   try
   {
      southPole = TimeZoneInfo.FindSystemTimeZoneById("Antarctica/South Pole Standard Time");
   }
   // Time zone does not exist; create it, store it in a text file, and return it
   catch
   {
      const string filename = @".\TimeZoneInfo.txt";
      bool found = false;
      
      if (File.Exists(filename))
      {
         StreamReader reader = new StreamReader(filename);
         string timeZoneInfo;
         while (reader.Peek() >= 0)
         {
            timeZoneInfo = reader.ReadLine();
            if (timeZoneInfo.Contains("Antarctica/South Pole"))
            {
               southPole = TimeZoneInfo.FromSerializedString(timeZoneInfo);
               reader.Close();
               found = true;
               break;
            }   
         }
      }
      if (!found)
      {               
         // Define transition times to/from DST
         TimeZoneInfo.TransitionTime startTransition = TimeZoneInfo.TransitionTime.CreateFloatingDateRule(new DateTime(1, 1, 1, 2, 0, 0), 10, 1, DayOfWeek.Sunday); 
         TimeZoneInfo.TransitionTime endTransition = TimeZoneInfo.TransitionTime.CreateFloatingDateRule(new DateTime(1, 1, 1, 2, 0, 0), 3, 3, DayOfWeek.Sunday);
         // Define adjustment rule
         TimeSpan delta = new TimeSpan(1, 0, 0);
         TimeZoneInfo.AdjustmentRule adjustment = TimeZoneInfo.AdjustmentRule.CreateAdjustmentRule(new DateTime(1989, 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+12:00) Antarctica/South Pole";
         string standardName = "Antarctica/South Pole Standard Time";
         string daylightName = "Antarctica/South Pole Daylight Time";
         TimeSpan offset = new TimeSpan(12, 0, 0);
         southPole = TimeZoneInfo.CreateCustomTimeZone(standardName, offset, displayName, standardName, daylightName, adjustments);
         // Write time zone to the file
         StreamWriter writer = new StreamWriter(filename, true);
         writer.WriteLine(southPole.ToSerializedString());
         writer.Close();
      }
   }
   return southPole;
}

Comentarios

Las aplicaciones que se basan en zonas horarias que no se definen normalmente en el registro de sistemas Windows o en la biblioteca de ICU en Linux y macOScan pueden usar el CreateCustomTimeZone método para crear instancias de las zonas horarias necesarias como TimeZoneInfo objetos. Después, la aplicación puede llamar al ToSerializedString método para convertir el objeto de zona horaria en una cadena.

El TimeZoneInfo objeto también debe almacenarse en una ubicación donde la aplicación pueda recuperarlo cuando sea necesario. Entre las posibles ubicaciones se incluyen:

  • Registro en sistemas Windows.

  • Un archivo de recursos de aplicación.

  • Un archivo externo, como un archivo de texto.

Se aplica a

Producto Versiones
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1

Consulte también