StringFormat によってフォーマットを指定する
(2017/04/26 14:21:01 created.)
(2017/05/24 16:58:41 modified.)
TextBlock コントロールなどでテキストを表示するときに、ViewModel から与えられたものを変換して表示したい場合には StringFormat が便利です。
MainViewModel.cs
namespace Tips_StringFormat.ViewModels
{
using System;
public class MainViewModel
{
/// <summary>
/// 新しいインスタンスを生成します。
/// </summary>
public MainViewModel()
{
this.Value = 1234.56789;
this.Integer = 123456789;
this.Text = "123456789";
this.Name = "田中 太郎";
this.Date = DateTime.Now;
}
/// <summary>
/// 小数を持つ数値を取得します。
/// </summary>
public double Value { get; private set; }
/// <summary>
/// 整数値を取得します。
/// </summary>
public int Integer { get; private set; }
/// <summary>
/// 数値の文字列表現を取得します。
/// </summary>
public string Text { get; private set; }
/// <summary>
/// 文字列を取得します。
/// </summary>
public string Name { get; private set; }
/// <summary>
/// 日付を取得します。
/// </summary>
public DateTime Date { get; private set; }
}
}
MainView.xaml
<Window x:Class="Tips_StringFormat.Views.MainView"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="MainView" Height="420" Width="525">
<StackPanel>
<GroupBox Header="数値の表示">
<StackPanel>
<TextBlock Text="{Binding Value, StringFormat={}{0:N2}}"/>
<TextBlock Text="{Binding Value, StringFormat={}{0:N3}}"/>
<TextBlock Text="{Binding Value, StringFormat={}{0:00000}}"/>
</StackPanel>
</GroupBox>
<GroupBox Header="価格の表示">
<StackPanel>
<TextBlock Text="{Binding Integer, StringFormat={}{0:C}}"/>
<TextBlock Text="{Binding Integer, StringFormat={}{0:C}, ConverterCulture=ja-JP}"/>
<TextBlock Text="{Binding Integer, StringFormat=定価{0:N0}円}"/>
<TextBlock Text="文字列による数値表現に StringFormat は効果がない" />
<TextBlock Text="{Binding Text, StringFormat={}{0:N2}円}"/>
</StackPanel>
</GroupBox>
<GroupBox Header="16 進数の表示">
<StackPanel>
<TextBlock Text="{Binding Integer, StringFormat={}{0:X}}"/>
<TextBlock Text="{Binding Integer, StringFormat={}0x{0:X8}}"/>
</StackPanel>
</GroupBox>
<GroupBox Header="日付の表示">
<StackPanel>
<TextBlock Text="{Binding Date}"/>
<TextBlock Text="{Binding Date, ConverterCulture=ja-JP}"/>
<TextBlock Text="{Binding Date, StringFormat={}{0:yyyy年MM月dd日 HH:mm:ss}}"/>
</StackPanel>
</GroupBox>
<GroupBox Header="マルチバインディング">
<TextBlock>
<TextBlock.Text>
<MultiBinding StringFormat="氏名:{0} 得点:{1:N0}点">
<Binding Path="Name"/>
<Binding Path="Integer"/>
</MultiBinding>
</TextBlock.Text>
</TextBlock>
</GroupBox>
</StackPanel>
</Window>
上記の例のように、StringFormat には数値書式指定文字列を指定します。数値書式指定文字列には次のようなものがあります。
書式指定子 | サポートするデータ型 | 説明 |
---|---|---|
"C" または "c" | すべての数値型 | 通貨として表示します。 |
"D" または "d" | 整数型のみ | 必要に応じて負の符号を付けて表示します。 |
"E" または "e" | すべての数値型 | 指数表記で表示します。 |
"F" または "f" | すべての数値型 | 必要に応じて負の符号を付けて整数または小数として表示します。 |
"G" または "g" | すべての数値型 | 固定小数点表記または指数表記のいずれかの最も簡潔な形式で表示します。 |
"N" または "n" | すべての数値型 | 必要に応じて負の符号を付け、桁区切り記号を付けて表示します。 |
"P" または "p" | すべての数値型 | 数値に 100 を掛けて、パーセント記号を付けて表示します。 |
"R" または "r" | Single, Double, BigInteger | 同じ数値にラウンドトリップした文字列を表示します。 |
"X" または "x" | 整数型のみ | 16 進数文字列に変換して表示します。"0x" のプレフィックスは付きません。 |
その他 | --- | 実行時に FormatException 例外がスローされます。 |
Tweet