はじめに
この記事内でやること
- Excelに書かれたブログタイトルを【Power Automate Desktop】を使って【ChatGPT】に自動入力してブログ記事を生成する
- 自動生成されたブログ記事をExcelに自動で貼り付ける
実際の画面
https://www.youtube.com/watch?v=UfB0rm-5L1M
事前に用意するもの
・Windows[ Microsoft Power Automate Desktop ]
・Chrome[ ChatGPT ]
・Excelにブログタイトルを入れておく
【Power Automate Desktop】全体の作業フロー
・事前準備
〜繰り返し〜
・記事の生成
・記事の加工
・Excelに書き込み
〜〜〜〜
・後処理
事前準備
ここでは生成する記事数の指定・アプリの起動・変数の設定などを行います。
- 入力ダイアログを表示
- テキストを数値に変換
- 実行中のExcelに添付
- 新しいChromeを起動する
- 変数の設定
- 変数の設定
- Excelワークシートの列名を取得する
- Excelワークシートの列名を取得する
[Power Automate Desktop]
入力ダイアログを表示 / テキストを数値に変換
生成する記事の数を入力します。(入力された数値=記事生成フローの繰り返しの回数)
入力ダイアログで生成された変数はテキスト型なので数値に変換しておきます。
実行中のExcelに添付
使うExcelブックを読み込みます。
実行中のExcelから読み込むので、フローを実行するさいは事前にExcelを開いておく必要があります。
新しいChromeを起動する
新しくChromeを起動してChatGPTを表示させます。
変数の設定 / Excelワークシートの列名を取得する
ここの処理はなくても問題ありませんが、後々わかりやすくするために行います。
ChatGPTに入力する文言 → 変数:prompt
Excelシートの列に名をつける
記事の生成
ここではChatGPTにブログタイトルを入力して記事を生成させます。
- Excelワークシートから列における最初の空の行を取得
- Webページのリンクをクリック
- Excelワークシートから読み取る
- Webページ内のテキストフィールドに入力する
- Webページのリンクをクリック
- ウィンドウのUI要素の上にマウスポインターを移動する
- 画像を待機
[Power Automate Desktop]
Excelワークシートから列における最初の空の行を取得 / Excelワークシートから読み取る
Excelシートから記事本文が空の行番号を取得して、そのブログタイトルを読み取ります。
Webページのリンクをクリック
ChatGPTの「New chat」をクリックします。
ChatGPTは同じチャット内でそれまでの流れを汲んで回答してくれます。それが影響して同じチャット内でブログ記事を連続で生成させると「全く同じ文章構成の記事」を生成してしまうのでここではそれを避けるために記事ごとに新しいチャット欄に切り替えます。
Webページ内のテキストフィールドに入力する / Webページのリンクをクリック
Excelから読み取ったブログタイトルを入力して送信します。
この時入力するテキストは「ブログタイトル」+「変数(prompt1)」なので、変数の内容を変えることで自由にChatGPTに指示を出すことができます。
画像を待機 / ウィンドウのUI要素の上にマウスポインターを移動する
下の画像が画面内にあるかどうかで文章生成が終わったかどうかを判断しています。
この時マウスポインターが画像に被っていると正しく認識されないので、適当なところに移動させています。
記事の加工
ここでは生成した記事に操作を加えます。
Q.なぜ「◆」を書き加えるの?
A. 後でExcelマクロを使って「◆」を「改行」に置換するのでその目印にするため
ChatGPTからデータを抽出するとき改行が消えてしまうので、Excel側で改行を補う必要があります。そのときの改行させる位置の目印として「◆」をつけています。
1.Webページ内のテキストフィールドに入力する
2.Webページのリンクをクリック
3.ウインドウのUI要素の上にマウスポインターを移動する
4.画像を待機
Webページ内のテキストフィールドに入力する
生成した文章の行末に「◆」を書き加えます。
Webページ内のテキストフィールドに入力する /~/ 画像を待機
ここは記事を生成すると同じです。
Excelに書き込み
- Webページからデータを抽出する
- ウィンドウにフォーカスする
- Excelワークシートから列における最初の空の行を取得
- Excelワークシートに書き込む
- Excelワークシート内のセルをアクティブ化
- Excelマクロを実行
[Power Automate]
Webページからデータを抽出する
生成した文章をWebページから抽出します。
実際に抽出した変数の中身は画像の通りです。
ここでは加工後のテキストが欲しいので、DataFromWebPage[3]
を指定して使います。
ウィンドウにフォーカスする
Excelにフォーカスを当てて表示させます。
Excelワークシートから列における最初の空の行を取得 / Excelワークシートに書き込む
Excelシートから記事本文が空の行を取得して、取得したDataFromWebPage[3]
の値を書き込みます。
Excelワークシート内のセルをアクティブ化 / Excelマクロを実行
アクティブセルに対して「◆」を「改行&改行」に置き換えるマクロを実行させます。
(ChatGPTに聞いたらマクロ書いてくれました)
Sub ReplaceSquaresWithNewlines()
'アクティブセルを取得
Dim cell As Range
Set cell = activeCell
'アクティブセルの内容を文字列として取得し、改行に置換
Dim text As String
text = cell.Value
text = Replace(text, "◆", vbCrLf & vbCrLf)
'改行に置換した文字列をアクティブセルに設定
cell.Value = text
End Sub
後処理
・Excelの保存
・Webブラウザーを閉じる
・メッセージを表示
<if>
・Desktopフローを実行
<Else>
・メッセージを表示
<End>
[Power Automate Desktop]
Excelの保存 / Webブラウザーを閉じる
Excelブックを保存して、ChatGPTを閉じます。
メッセージを表示
続けてブログの投稿を行うかのメッセージを表示させます。
"はい"を押した場合このままブログの自動投稿フローが始まりますが、この記事では解説しません。
"いいえ"を押すと「自動処理が終わりました。」のメッセージウィンドウが出て作業フローが終了します。
さいごに
AIと自動化の組み合わせを実際に活用してみて、そのパワーに私自身驚いています。
今回はブログ記事の自動化をテーマにしましたが、他にもいろいろな事で応用できそうだなぁっと実感しているところです。
苦労した点
・コピペするときの改行問題
改行の目印を付けたくてもAIが指示通りに文章を生成してくれない
今後したいこと
・生成文章が途切れることがあるので条件分岐を足して対応したい。
・記事のタグも同様に生成したい。