本記事では、Power Automate Desktopを活用するときに、よくある質問と回答を紹介します。
質問:Web上から指定した情報だけを抽出したい
ブラウザーでWebサイトを開いた際に、毎日変動する情報の中から、特定のものだけを抽出するにはどのようにすればよいでしょうか?指定した要素の値のみを取得すると翌日には値が変わっており、エラーが発生します。
回答:取得した情報から必要な情報を検索し、式を用いて値を抽出します。
Webサイトより取得したデータを検索し、指定した情報だけを抽出する方法をご紹介します。
データを取得する際には、例えば天気予報や株価など、特定の要素が時間や日によって変動することを考慮する必要があります。
今回は気象庁のサイトの全国の天気予報(https://www.jma.go.jp/bosai/forecast/)から、指定した地点の明日の天気と最低/最高気温を抽出します。
【手順】
1. フローを作成し、アクション「ブラウザー自動化」からWebブラウザーの起動を選択します。
今回はMicrosoft Edge(以下Edge)を使用するため「新しい Microsoft Edge を起動」を選択し、フローにドラッグアンドドロップします。
2. アクションの設定画面が表示されるので、初期URLに気象庁のサイト「https://www.jma.go.jp/bosai/forecast/」を設定し、[保存]ボタンをクリックします。他の設定項目はデフォルトのままとします。
3. 次にデータを抽出します。アクション「ブラウザー自動化」>「Web データ抽出」から「Web ページからデータを抽出する」を選択し、フローにドラッグアンドドロップします。
4. アクションの設定画面が表示されるので、設定画面を開いた状態で、手順2で設定したURLをEdgeで開きます。
5. Edgeでサイトを開くと「ライブ Web ヘルパー」ウィンドウが立ち上がり、要素のセレクター状態となります。画面に表示された天気予報の表の一部を右クリックし、「HTML テーブル全体を抽出する」を選択します。
6. ライブ Web ヘルパーに、天気予報のテーブル情報が表示されます。データが抽出できたことを確認し、[終了]ボタンをクリックします。
7. 「Web ページからデータを抽出する」設定画面で[保存]ボタンをクリックします。
設定項目はデフォルトのままとします。
8. 次に、抽出した情報から取得したい値を検索します。アクション「変数」>「データ テーブル」から「データ テーブル内で検索または置換する」を選択し、フローにドラッグアンドドロップします。
9. 「データ テーブル」と、「検索するテキスト」を設定します。
データ テーブルの入力ボックスをクリックし、変数「DataFromWebPage」を選択します。
検索するテキストには、今回は札幌の情報だけ抽出したいので「札幌」と入力し、[保存]ボタンをクリックします。
10. ここで一旦テストを実施します。左上の[実行]アイコンをクリックします。
11. テスト完了後、フロー変数「DataFromWebPage」をダブルクリックして変数の値を確認します。画面の表が取得できていることが分かりました。
12. 次にフロー変数「DataTableMatches」をダブルクリックして変数の値を確認します。するとRowに「10」という数字が入っています。
検索条件に設定した「札幌」の情報は10行目にあるということが分かります。
13. 抽出したデータから必要な値のみをファイルに書き込み、確認します。
アクション「ファイル」から「テキストをファイルに書き込む」を選択し、フローにドラッグアンドドロップします。
14. 「①ファイル パス」、「②書き込むテキスト」、「③ファイルが存在する場合」を以下のとおり設定します。他の設定項目はデフォルトのままとします。
【設定値】
項目 | 設定値 |
---|---|
① | C:\tmp\test\札幌の明日の天気.csv |
② | %DataFromWebPage[DataTableMatches[0]['Row'] + 0]['value #3']%,%DataFromWebPage[DataTableMatches[0]['Row'] + 3]['value #3']% |
③ | 「内容を追加する」を選択 |
※ ①は環境に合わせて適宜変更してください。
【②の解説】
変数「DataFromWebPage」から指定した要素を参照します。
手順12で確認したように、’Row’の値は10がセットされています。
そのため、インデックス[0][10]を参照し、+0とすることで数値型に変換します。
‘value #3’は、手順11で変数の値を確認した際に、「value #3」という列は明日の天気を表している列であることが分かります。
つまりこの式は、10行目と13行目の列value #3のデータをカンマ区切りで取得しているということになります。
15. 最後にブラウザーを閉じます。アクション「ブラウザー自動化」>「Webブラウザーを閉じる」を選択し、フローにドラッグアンドドロップします。
16. デフォルト設定のまま[保存]ボタンをクリックします。
フローの作成手順は以上です。
17. 左上の保存アイコンからフローを保存し、フローを実行します。
18. 実行後、指定したファイル パスに札幌の明日の天気,最低/最高気温が表示されていることが確認できました。
以上です。
最後に
テンダでは、「こんなプロジェクトに挑戦したい」「こんなチームで働きたい」「理想のチームを創りたい」と願う仲間を求めています。
カジュアル面談も随時受付中です。ぜひ一度お話ししましょう