Lire en anglais

Partager via


IFormattable Interface

Définition

Fournit les fonctionnalités qui permettent de mettre en forme la valeur d'un objet en une représentation de chaîne.

public interface IFormattable
[System.Runtime.InteropServices.ComVisible(true)]
public interface IFormattable
Dérivé
Attributs

Exemples

L'exemple suivant définit une classe Temperature qui implémente l'interface IFormattable . La classe prend en charge quatre spécificateurs de format : « G » et « C », qui indiquent que la température doit être affichée en Celsius ; « F », qui indique que la température doit être affichée en Fahrenheit; et « K », qui indique que la température doit être affichée dans Kelvin. En outre, l’implémentation IFormattable.ToString peut également gérer une chaîne de format qui est null ou vide. Les deux ToString autres méthodes définies par la Temperature classe encapsulent simplement un appel à l’implémentation IFormattable.ToString .

using System;
using System.Globalization;

public class Temperature : IFormattable
{
   private decimal temp;

   public Temperature(decimal temperature)
   {
      if (temperature < -273.15m)
        throw new ArgumentOutOfRangeException(String.Format("{0} is less than absolute zero.",
                                              temperature));
      this.temp = temperature;
   }

   public decimal Celsius
   {
      get { return temp; }
   }

   public decimal Fahrenheit
   {
      get { return temp * 9 / 5 + 32; }
   }

   public decimal Kelvin
   {
      get { return temp + 273.15m; }
   }

   public override string ToString()
   {
      return this.ToString("G", CultureInfo.CurrentCulture);
   }

   public string ToString(string format)
   {
      return this.ToString(format, CultureInfo.CurrentCulture);
   }

   public string ToString(string format, IFormatProvider provider)
   {
      if (String.IsNullOrEmpty(format)) format = "G";
      if (provider == null) provider = CultureInfo.CurrentCulture;

      switch (format.ToUpperInvariant())
      {
         case "G":
         case "C":
            return temp.ToString("F2", provider) + " °C";
         case "F":
            return Fahrenheit.ToString("F2", provider) + " °F";
         case "K":
            return Kelvin.ToString("F2", provider) + " K";
         default:
            throw new FormatException(String.Format("The {0} format string is not supported.", format));
      }
   }
}

L’exemple suivant appelle ensuite l’implémentation directement ou à l’aide IFormattable.ToString d’une chaîne de format composite.

public class Example
{
   public static void Main()
   {
      // Use composite formatting with format string in the format item.
      Temperature temp1 = new Temperature(0);
      Console.WriteLine("{0:C} (Celsius) = {0:K} (Kelvin) = {0:F} (Fahrenheit)\n", temp1);

      // Use composite formatting with a format provider.
      temp1 = new Temperature(-40);
      Console.WriteLine(String.Format(CultureInfo.CurrentCulture, "{0:C} (Celsius) = {0:K} (Kelvin) = {0:F} (Fahrenheit)", temp1));
      Console.WriteLine(String.Format(new CultureInfo("fr-FR"), "{0:C} (Celsius) = {0:K} (Kelvin) = {0:F} (Fahrenheit)\n", temp1));

      // Call ToString method with format string.
      temp1 = new Temperature(32);
      Console.WriteLine("{0} (Celsius) = {1} (Kelvin) = {2} (Fahrenheit)\n",
                        temp1.ToString("C"), temp1.ToString("K"), temp1.ToString("F"));

      // Call ToString with format string and format provider
      temp1 = new Temperature(100)      ;
      NumberFormatInfo current = NumberFormatInfo.CurrentInfo;
      CultureInfo nl = new CultureInfo("nl-NL");
      Console.WriteLine("{0} (Celsius) = {1} (Kelvin) = {2} (Fahrenheit)",
                        temp1.ToString("C", current), temp1.ToString("K", current), temp1.ToString("F", current));
      Console.WriteLine("{0} (Celsius) = {1} (Kelvin) = {2} (Fahrenheit)",
                        temp1.ToString("C", nl), temp1.ToString("K", nl), temp1.ToString("F", nl));
   }
}
// The example displays the following output:
//    0.00 °C (Celsius) = 273.15 K (Kelvin) = 32.00 °F (Fahrenheit)
//
//    -40.00 °C (Celsius) = 233.15 K (Kelvin) = -40.00 °F (Fahrenheit)
//    -40,00 °C (Celsius) = 233,15 K (Kelvin) = -40,00 °F (Fahrenheit)
//
//    32.00 °C (Celsius) = 305.15 K (Kelvin) = 89.60 °F (Fahrenheit)
//
//    100.00 °C (Celsius) = 373.15 K (Kelvin) = 212.00 °F (Fahrenheit)
//    100,00 °C (Celsius) = 373,15 K (Kelvin) = 212,00 °F (Fahrenheit)

Remarques

L’interface IFormattable convertit un objet en sa représentation sous forme de chaîne en fonction d’une chaîne de format et d’un fournisseur de format.

Une chaîne de format définit généralement l’apparence générale d’un objet. Par exemple, le .NET Framework prend en charge les éléments suivants :

Vous pouvez également définir vos propres chaînes de format pour prendre en charge la mise en forme de vos types définis par l’application.

Un fournisseur de format retourne un objet de mise en forme qui définit généralement les symboles utilisés pour convertir un objet en sa représentation sous forme de chaîne. Par exemple, lorsque vous convertissez un nombre en valeur monétaire, un fournisseur de format définit le symbole monétaire qui apparaît dans la chaîne de résultat. Le .NET Framework définit trois fournisseurs de formats :

En outre, vous pouvez définir vos propres fournisseurs de formats personnalisés pour fournir des informations spécifiques à la culture, à la profession ou au secteur utilisées dans la mise en forme. Pour plus d’informations sur l’implémentation de la mise en forme personnalisée à l’aide d’un fournisseur de format personnalisé, consultez ICustomFormatter.

L’interface IFormattable définit une méthode unique, ToString, qui fournit des services de mise en forme pour le type d’implémentation. La ToString méthode peut être appelée directement. En outre, elle est appelée automatiquement par les Convert.ToString(Object) méthodes et Convert.ToString(Object, IFormatProvider) et par les méthodes qui utilisent la fonctionnalité de mise en forme composite dans le .NET Framework. Ces méthodes incluent Console.WriteLine(String, Object), String.Formatet StringBuilder.AppendFormat(String, Object), entre autres. La ToString méthode est appelée pour chaque élément de format dans la chaîne de format de la méthode.

L’interface IFormattable est implémentée par les types de données de base.

Notes pour les responsables de l’implémentation

Les classes qui nécessitent plus de contrôle sur la mise en forme des chaînes que ToString() ne le fournit doivent implémenter IFormattable.

Une classe qui implémente IFormattable doit prendre en charge le spécificateur de format « G » (général). Outre le spécificateur « G », la classe peut définir la liste des spécificateurs de format qu’elle prend en charge. En outre, la classe doit être préparée pour gérer un spécificateur de format qui est null. Pour plus d’informations sur la mise en forme et les codes de mise en forme, consultez Mise en forme des types

Méthodes

ToString(String, IFormatProvider)

Met en forme la valeur de l’instance actuelle en utilisant le format spécifié.

S’applique à

Produit Versions
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 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 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Voir aussi