閱讀英文

共用方式為


IFormattable.ToString(String, IFormatProvider) 方法

定義

使用指定的格式,格式化目前執行個體的值。

public string ToString(string format, IFormatProvider formatProvider);
public string ToString(string? format, IFormatProvider? formatProvider);

參數

format
String

要使用的格式。

-或-

若要使用為 IFormattable 實作類型所定義的預設格式,則為 Null 參考 (在 Visual Basic 中為 Nothing)。

formatProvider
IFormatProvider

用於格式化值的提供者。

-或-

若要取得作業系統之目前地區設定中的數值格式資訊,則為 Null 參考 (在 Visual Basic 中為 Nothing)。

傳回

採用指定格式之目前執行個體的值。

範例

下列範例示範實 Temperature 作 方法的 ToString 類別。 此程式碼範例是提供給 類別之較大範例的 IFormattable 一部分。

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));
      }
   }
}

備註

方法 ToString 會將值轉換成可以用多種方式表示的字串表示。 其精確格式取決於特定文化特性、專業或產業所定義的特定符號或指定順序。 您可以直接呼叫 方法。 它也會由 Convert.ToString(Object)Convert.ToString(Object, IFormatProvider) 方法自動呼叫,以及使用.NET Framework中複合格式功能的方法,例如 String.Format(String, Object[])Console.WriteLine(String, Object[])StringBuilder.AppendFormat(String, Object[]) 。 (如需詳細資訊,請參閱 複合格式。)

複合格式方法會針對格式字串中的每個格式專案呼叫 ToString 方法一次。 傳遞至 方法的參數取決於呼叫的特定格式方法,以及格式專案的內容,如下所示:

注意

只有當物件 ToString 未傳遞 ICustomFormatter 格式提供者,或 Format 自訂格式提供者的 方法傳回 null 時,複合格式方法才會呼叫物件的實作。

.NET Framework包含三個格式提供者,全部實作 IFormatProvider 介面:

  • NumberFormatInfo 提供數值格式資訊,例如用於小數和群組分隔符號的字元,以及貨幣符號在貨幣值中的拼字和放置。

  • DateTimeFormatInfo 會提供日期相關和時間相關的格式資訊,例如月份的位置、日和日期模式中的年份。

  • CultureInfo 包含特定文化特性中的預設格式資訊,包括數值格式資訊,以及日期相關與時間相關的格式資訊。

此外,您可以定義自己的自訂格式提供者。

給實施者的注意事項

方法 ToString(String, IFormatProvider) 必須支援 「G」 (一般) 格式規範。 除了 「G」 規範之外,類別還可以定義它支援的格式規範清單。 此外,類別必須準備好處理為 的格式規範 null 。 如需格式化和格式化程式碼的詳細資訊,請參閱 格式化類型

適用於

產品 版本
.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, 10
.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

另請參閱