次の方法で共有


カスタム関数でデータを受信して​​処理する

カスタム関数が Excel の機能を強化する方法の 1 つは、( WebSocket を介して) Web やサーバーなどのブック以外の場所からデータを受信することです。 外部データを要求するには、 Fetch などの API を使用するか、サーバーと対話するための HTTP 要求を発行する標準 Web API である XmlHttpRequest(XHR)を使用します。

重要

Excel カスタム関数は、次のプラットフォームで使用できます。

  • Office on the web
  • Windows での Office
    • Microsoft 365 サブスクリプション
    • retail 永久 Office 2016 以降
    • ボリューム ライセンスの永続的な Office 2021 以降
  • Office on Mac

Excel カスタム関数は現在、次ではサポートされていません。

  • Office on iPad
  • Windows での Office 2019 以前のボリューム ライセンスの永続的バージョン

API から時間をストリーミングするカスタム関数の GIF。

外部ソースからデータを返す関数

カスタム関数が外部ソースからデータを取得する場合には、以下のことを実行する必要があります。

  1. JavaScript Promiseを Excel に返します。
  2. コールバック関数を使用して、最終的な値で Promise を解決します。

Fetch の使用例

次のコード サンプルでは、 webRequest 関数は、現在国際宇宙ステーションにいるユーザーの数を追跡する架空の外部 API に到達します。 関数は JavaScript Promise を返し、 fetch を使用して架空の API から情報を要求します。 結果のデータは JSON に変換され、 names プロパティは文字列に変換され、promise を解決するために使用されます。

独自の機能を開発するときに、Web 要求が時間内に完了しない場合は、アクションを実行するか、複数の API 要求をバッチ処理することを検討してください。

/**
 * Requests the names of the people currently on the International Space Station.
 * Note: This function requests data from a hypothetical URL. In practice, replace the URL with a data source for your scenario.
 * @customfunction
 */
function webRequest() {
  let url = "https://www.contoso.com/NumberOfPeopleInSpace"; // This is a hypothetical URL.
  return new Promise(function (resolve, reject) {
    fetch(url)
      .then(function (response){
        return response.json();
        }
      )
      .then(function (json) {
        resolve(JSON.stringify(json.names));
      })
  })
}

注:

fetchを使用すると、コールバックのネストが回避され、場合によっては XHR に適している場合があります。

XHR の使用例

次のコード サンプルでは、 getStarCount 関数は Github API を呼び出して、特定のユーザーのリポジトリに与えられた星の量を検出します。 これは、JavaScript Promiseを返す非同期関数です。 Web 呼び出しからデータが取得されると、データをセルに返す promise が解決されます。

/**
 * Gets the star count for a given Github organization or user and repository.
 * @customfunction
 * @param userName string name of organization or user.
 * @param repoName string name of the repository.
 * @return number of stars.
 */
async function getStarCount(userName: string, repoName: string) {

  const url = "https://api.github.com/repos/" + userName + "/" + repoName;

  let xhttp = new XMLHttpRequest();

  return new Promise(function(resolve, reject) {
    xhttp.onreadystatechange = function() {
      if (xhttp.readyState !== 4) return;

      if (xhttp.status == 200) {
        resolve(JSON.parse(xhttp.responseText).watchers_count);
      } else {
        reject({
          status: xhttp.status,

          statusText: xhttp.statusText
        });
      }
    };

    xhttp.open("GET", url, true);

    xhttp.send();
  });
}

ストリーミング関数を作成する

ストリーム カスタム関数を使用すると、繰り返し更新されるセルにデータを出力でき、ユーザーが明示的に何かを更新する必要ありません。 これは、カスタム関数のチュートリアルの関数のように、サービス オンラインのライブ データを確認する際に便利です。

ストリーミング関数を宣言するには、次の 2 つのオプションのいずれかを使用できます。

  • @streaming JSDoc タグ。
  • CustomFunctions.StreamingInvocation呼び出しパラメーター。

以下のコード サンプルは、毎秒ごとに結果に数値を追加するカスタム関数です。 このコードについては、次の点に注意してください。

  • Excel は、setResult メソッドを使用して自動的に新しい値を表示します。
  • 2 番目の入力パラメーターの invocation は、[オートコンプリート] メニューから関数が選択された場合、Excel のエンドユーザーに表示されません。
  • onCanceled コールバックは、関数が取り消されたときに実行される関数を定義します。
  • ストリーミングは、必ずしも Web 要求の作成に関連付けられているわけではありません。 この場合、関数は Web 要求を行いませんが、設定された間隔でデータを取得するため、ストリーミング invocation パラメーターを使用する必要があります。
/**
 * Increments a value once a second.
 * @customfunction INC increment
 * @param {number} incrementBy Amount to increment
 * @param {CustomFunctions.StreamingInvocation<number>} invocation
 */
function increment(incrementBy, invocation) {
  let result = 0;
  const timer = setInterval(() => {
    result += incrementBy;
    invocation.setResult(result);
  }, 1000);

  invocation.onCanceled = () => {
    clearInterval(timer);
  };
}

注:

ストリーミング関数から動的スピル配列を返す方法の例については、「 カスタム関数から複数の結果を返す: コード サンプル」を参照してください。

関数を取り消す

Excel は、次の状況で関数の実行を取り消します。

  • ユーザーが、関数を参照するセルを編集または削除した場合。
  • 関数の引数 (入力) の 1 つが変更されたとき。 この場合、キャンセルに続いて、関数の新しい呼び出しがトリガーされます。
  • ユーザーが手動で再計算をトリガーしたとき。 この場合、キャンセルに続いて、関数の新しい呼び出しがトリガーされます。

また、要求が発生したときに、オフラインの場合でも、ケースを処理する既定のストリーミング値を設定することもできます。

注:

また、 @cancelable JSDoc タグを使用する cancelable 関数と呼ばれる関数のカテゴリもあります。 取り消し可能な関数を使用すると、要求の途中で Web 要求を終了できます。

ストリーミング関数では @cancelable タグを使用できませんが、ストリーミング関数には onCanceled コールバック関数を含めることができます。 @cancelable JSDoc タグを使用できるのは、1 つの値を返す非同期カスタム関数のみです。 @cancelable タグの詳細については、「Autogenerate JSON metadata: @cancelable」を参照してください。

呼び出しパラメーターを使用する

invocation パラメーターは、既定ではカスタム関数の最後のパラメーターです。 invocation パラメーターは、セルに関するコンテキスト (アドレスや内容など) を提供し、setResult メソッドと onCanceled イベントを使用して、関数がストリーム処理 (setResult) または取り消されたとき (onCanceled) を定義できます。

呼び出しハンドラーは、web 要求を処理するために CustomFunctions.StreamingInvocation 型であるか、 CustomFunctions.CancelableInvocation である必要があります。

invocation引数のその他の潜在的な使用方法と、それが Invocation オブジェクトに対応する方法については、「呼び出しパラメーター」を参照してください。

WebSocket 経由のデータ受信

カスタム関数内で、WebSocket を使用して、サーバーとの固定接続経由でデータを交換することができます。 WebSocket を使用すると、カスタム関数はサーバーとの接続を開き、特定のイベントが発生したときにサーバーからメッセージを自動的に受信できます。サーバーでデータを明示的にポーリングする必要はありません。

WebSocket の使用例

以下のコード サンプルは、WebSocket 接続を確立し、サーバーからの各受信メッセージを記録します。

let ws = new WebSocket('wss://bundles.office.com');

ws.onmessage(message) {
    console.log(`Received: ${message}`);
}

ws.onerror(error){
    console.err(`Failed: ${error}`);
}

次の手順

関連項目