XMLにおける文字参照と実体参照

XML 文書の内容や属性の値などで特別な値を記述する場合に使用する文字参照と実体参照について解説します。

(Last modified: )

文字参照

キーボードから文字を直接入力する代わりに文字に対応する文字番号を使って文字を記述することができます。この方法を XML では文字参照と呼びます。文字番号は文字コードの一つである ISO 10646 で定められた文字コードを使用します。

例として次の XML 文書をみてください。

<?xml version="1.0" encoding="UTF-8" ?>
<foods>
  <food>
    <name>バナナナナ&#8482;</name>
  </food>
</foods>

name 要素の内容として"バナナナナ"のあとに &#8482; という値が記述されています。これは商標記号の文字を文字参照を使って記述したものです。この XML 文書をブラウザで表示してみると &#8482; が記述されているところに代わりに商標記号の文字が表示されています。

文字参照(1)

文字参照は 10 進数または 16 進数の文字番号を使って次のように記述します。

&#(10進数の文字番号);
&#x(16進数の文字番号);

例えば 10 進数で記述する場合は &#6749; のように記述し、 16 進数で記述する場合は &#x1A5D; のように記述します。先ほどの例で商標記号を 10 進数の &#8482; と記述しましたが、 16 進数の &#x2122; と記述しても同じ結果となります。

文字参照の一覧の中で文字と文字番号の対応表の一部を下記に記述します。すべて 10 進数ですので 16 進数で記述する場合は文字番号の部分を 16 進数に変換してください。

&#165;  円記号 \
&#169;  著作権表示文字 ©
&#174;  登録商標記号 ®
&#176;  度記号 °
&#188;  1/4 ¼
&#189;  1/2 ½
&#190;  3/4 ¾
&#8482; 商用記号 ™
&#8721; シグマ ∑
&#8730; ルート √
&#8747; 積分 ∫

またこのあとで解説する実体参照で使われる文字についても文字参照で記述することができます。

&  アンパサンド &
<  小なり記号 <
>  大なり記号 >
"  二重引用符 "
'  一重引用符 '

実体参照

& や < など一部の特殊な文字については要素の内容にそのまま記述するとエラーになる文字があります。

例として次の XML 文書をみてください。

<?xml version="1.0" encoding="UTF-8" ?>
<foods>
  <food>
    <name>バナナ&リンゴ</name>
  </food>
</foods>

name 要素の内容の中に「バナナ&リンゴ」と & を記述しています。この XML 文書をブラウザで表示してみると次のようにエラーが表示されます。

実体参照(1)

このようなエラーとなる文字に関しては先に解説した文字参照を使って記述することもできますが、覚えにくい文字番号ではなく特別な文字列を使って記述することができます。この方法を XML では実体参照といいます。先ほどのサンプルの場合なら & と記述する代わりに実体参照の &amp; と記述してください。

<?xml version="1.0" encoding="UTF-8" ?>
<foods>
  <food>
    <name>バナナ&amp;リンゴ</name>
  </food>
</foods>

この XML 文書をブラウザで表示してみると今度は正常に表示されました。

実体参照(2)

XML で実体参照が用意されているのは次の 5 つだけです。( HTML の場合は他にもありますが XML の場合は 5 つだけです)。

&amp;   アンパサンド &
&lt;    小なり記号 <
&gt;    大なり記号 >
&quot;  二重引用符 "
&apos;  一重引用符 '

& および < については要素の内容や属性の値として記述する場合など常に実体参照で記述する必要があります。それに対して " および ' については要素の内容に記述する場合はそのまま記述してもエラーとなりませんが属性の値として記述する場合には実体参照で記述する必要があります。

> については要素の内容の中で ]]> と記述する必要がある場合だけそのまま記述するとエラーとなりますので実体参照を使って ]]&gt; と記述します。(ただエラーにならない場合も > については &gt; と記述しておいた方がケアレスミスは少なくなるかもしれません)。

なお & および < についても、このあとで解説する CDATA セクションの中で記述する場合にはそのまま記述することができます。

-- --

XML 文書の内容や属性の値などで特別な値を記述する場合に使用する文字参照と実体参照について解説しました。

( Written by Tatsuo Ikura )

Profile
profile_img

著者 / TATSUO IKURA

プログラミングや開発環境構築の解説サイトを運営しています。