0
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Microsoft Word 今日のトリビア Wordのフィールドコードの書式設定スイッチはすべて同じではない

Posted at

コンマ付き小数2桁

式(Formula)フィールド

Formulaフィールドは半角のイコールから始めます。

{ =1900.22 \#"0,.00" }

Webでは左上から右下へのスラッシュですが、日本語版のWordでは円記号(¥)になります。
実際の入力はF9を押してこのような感じになります。
{ =1900.22 ¥#"0,.00" }

という感じです。

結果

日本語版のWordでは
1,900.22と表示されます。

補足 EQは別

EQフィールドは数式の表示になります。

補足2 同様の効果はQuoteフィールド

Quoteフィールドでも同じ書式スイッチが使える。

{ Qutote "1900.22" #"0,.00" }

差し込み印刷Mergefield

Mergefiledは差し込み印刷以外使えなさそうですが、日付や数字の書式を設定するのに重宝します。

{ Mergefield "1900.22" #"0,.00" }
{ Mergefield 1900.22 #"0,.00" }

意図しない結果

この結果はどうなるでしょうか?
答えは
0.22になります。

考えられる原因

  1. フィールドコードの書式設定スイッチが固有。(というか公式で書いてあるのはこういったことを指していると思われる)
  2. Mergefieldに今入れているのはフィールドの値ではなくフィールド名として解釈されている。
  3. 実際のフィールドの値以外は文字列として解釈している。

実際に値を挿入するときのMergefieldの書式スイッチ

{ MERGEFIELD FieldName &Yen;#"0,.00" }

値を差し込んでいる状態のときは書式スイッチが正常に作動します。
{ MERGEFIELD FieldName &Yen;#"#,##0.00" }
こちらもExcelと同じものになりますが、作動します。しかしこのExcelと同じ書式はQuote には効果がありません。意図しない結果になります。

##数字も日付も使えるのはQuote
差し込みではない日付の書式指定、数値の書式指定はQuoteが両方できます。

{ Quote "2022/5/10 21:00:00" @"ggge年M月d日(aaa) H:mm"}

カッコやコロンは全角で書くと全角になります。つまり数字だけ半角ということが可能です。

{ Quote "1900.22" #"0,.00"}
もちろんこちらも有効です。
こうしたどちらも有効なフィールドコードはQUOTEの他FILESIZEもそうです。またREFフィールドもそうです。

前述のように{ QUOTE FieldName &Yen;#"#,##0.00" }はエラーです。

だからといってQuoteでMergefieldを変換することはできない

単純に値だけ書いたMergeFieldはQuoteで書式設定できない

{ Quote { Mergefield "1900.55" } #"0,.00"}
こういうのはエラーになります。

Quoteは差し込みの値は変換できます。

{ Quote { Mergefield FieldName } #"0,.00"}
このようにして入ってきた値が1900.55であれば
1,900.55
と表示されます。
一見どうでもいいようですが、次でこれを使います。

ExcelのTEXT関数。VBAのFormat関数のようにいきません。

一旦書式を設定すると、その値が参照される

また、差込時に小数点をカットします
{ Mergefield Field.value #"0,"}
1901になります。
これにブックマークをつけて、REFで参照したときに
{Ref bookmmark ¥#"#,##0.00"}
としても値は1900.55ではなく1901.00となります。
つまりMegefieldで書式設定をして端数を消すと、以後、もとの値ではなく、書式設定後の値が参照されています。
それではどうするか。ここで前述のQuoteに更にブックマークを使います。
{ Quote { Mergefield FieldName } #"0,"}
このようにMeregeFieldにブックマークを挿入します。
これを{ Ref bookmark } とすると表示された値ではなく、もとの値を参照して書式設定することができます。

#まとめ
各フィールドの固有スイッチは他のフィールドでは無効な場合がある。
Wordで数値、日付で書式設定を使うときはQuoteを使うのが最も汎用性が高い。
数値はFormula フィールドは有効だが、日付は有効ではない。
数値の書式指定はMergefieldでは差し込まれた値には有効に作用するが、ラベル名のテキストは失敗する。
FILESIZE REFでも固有のスィッチが効く。

参考

Word でフィールドを挿入、編集、表示する
Word のフィールド コード一覧
フィールドの結果を書式設定する
Word 文書または Outlook メッセージにブックマークを追加または削除する
【Word】差し込み印刷のカンマ、桁数、日付時刻、パーセントの表示形式の設定と変更 - わえなび

0
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?