FILTERXML 関数は、指定された xpath を使用して XML コンテンツから特定のデータを返します。
注
- FILTERXML 関数は、Excel for the Web および Excel for Mac では使用できません。
- この関数は Excel for Mac の関数ギャラリーに表示される場合がありますが、Windows オペレーティング システムの機能に依存しているため、Mac では結果が返されません。
構文
FILTERXML(XML, XPath)
FILTERXML 関数の書式には、次の引数があります。
| 引数 | 説明 |
|---|---|
|
Xml 必須 |
有効な XML 形式の文字列 |
|
Xpath 必須 |
標準の XPath 形式の文字列 |
注
- XML が無効な場合は、エラー値 #VALUE! が返されます。
- XML に無効なプレフィックスを持つ名前空間が含まれている場合は、エラー値 #VALUE! が返されます。
使用例
この例では、セル B2 で返される XML データに対して FILTERXML 関数を使用します。これは、セル B1 の Web クエリに対する WEBSERVICE 関数の結果によって提供されます。
FILTERXML のデータはセル B3:B5 と C3:C5 で返され、Wikipedia で最近更新された 3 つのクエリ結果とその更新時刻 (UTC では "協定世界時" で) が表示されます。
セル B3:B5 には、式 =FILTERXML(B3,"//rc/@title") が含まれています。
セル C3:C5 には、式 =FILTERXML(B3,"//rc/@timestamp") が含まれています。注
現在のバージョンの Microsoft 365 がある場合は、出力範囲の左上のセルに数式を入力し、 Enter キーを押して数式を動的配列数式として確認できます。 それ以外の場合、最初に出力範囲を選択し、出力範囲の左上のセルに数式を入力し、CTRL+SHIFT+ENTERキーを押して確定し、従来の配列数式として数式を入力する必要があります。 Excel によって、数式の先頭と末尾に中かっこが挿入されます。 配列数式の詳細については、「配列数式のガイドラインと例」を参照してください。
FILTERXML を ENCODEURL および WEBSERVICE 関数と組み合わせて使用することもできます。 たとえば、markitondemand.com api サービスを使用して、会社の株式に関する情報を返すことができます。
=WEBSERVICE("http://dev.markitondemand.com/MODApis/Api/Quote/xml?symbol="&ENCODEURL(C2))
セル C2 にストック ティッカーがある場所。
その後、FILTERXML 関数を使用して、その在庫に関する特定のデータを抽出できます。 たとえば、セル C2 で在庫ティッカーの最終価格を取得するには、次の値を使用できます。
=FILTERXML(WEBSERVICE("http://dev.markitondemand.com/MODApis/Api/Quote/xml?symbol="&ENCODEURL(C2)),"//QuoteApiModel/Data/LastPrice")
補足説明
Excel Tech Community の専門家にいつでも依頼したり、コミュニティでサポートを受けたりすることができます。