FILTERXML 関数

適用先
Excel for Microsoft 365 Excel 2024 Excel 2021 Excel 2019 Excel 2016

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! が返されます。

使用例

  1. この例では、セル B2 で返される XML データに対して FILTERXML 関数を使用します。これは、セル B1 の Web クエリに対する WEBSERVICE 関数の結果によって提供されます。
    FILTERXML 関数の例
    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 によって、数式の先頭と末尾に中かっこが挿入されます。 配列数式の詳細については、「配列数式のガイドラインと例」を参照してください。

  2. 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 の専門家にいつでも依頼したり、コミュニティでサポートを受けたりすることができます。