VOOZH about

URL: https://qiita.com/yuyanz/items/5c96232d188ecfb2544b

⇱ 【M365 Copilot】自由にツールを使えない現場で始めるちょいRPA #PowerShell - Qiita


👁 Image
53

Go to list of users who liked

38

Share on X(Twitter)

Share on Facebook

Add to Hatena Bookmark

👁 Image
【2026年上半期】AI活用を振り返ろう!
Qiita Tech Festa20262026年7月13日まで開催中!

【M365 Copilot】自由にツールを使えない現場で始めるちょいRPA

53
Last updated at Posted at 2026-06-25

この記事はGitHub Copilotと一緒に書きました。

1. はじめに

「業務を自動化したいけど、自由にツールを使えない」「コーディングエージェントや Playwright が職場ルールで使えない」という場面、ありませんか?
私の周りでも、セキュリティと運用ルールの観点で使えるツールがかなり限定されるケースがあります。

そこで今回は、Microsoft 365 Copilot と PowerShell を組み合わせて、まずは PowerShell 単体で完結する 自動化方法を紹介します。
また、今回紹介する”UI オートメーション”の良さは、画面が実際に動くことです。
誰が見ても「あ、勝手にやってくれている」と伝わるのでとても分かりやすいです。

この記事のゴールは次の2つです。

  1. PowerShell 単体で回せる現実的な自動化の例を知る
  2. Copilot への相談プロンプトを理解する

UI オートメーションはマウス操作や画面フォーカス、表示タイミングの影響を受けやすく、不安定になりやすいです。
本命としては Playwright や API 連携のほうが堅いです。
しかし、今回の方法が必要な場合もあると思います。
まず Copilot など目の前にある AI を活用することで、業務効率化ができるというインパクトを出すことができることを証明する。その次に何か便利なAIを導入するなど最初の「突破口」のように活用することを想定しています。

2. 前提・環境情報

今回の基本構成は「PowerShell 単体で完結、Excel は発展編で任意追加」です。

レイヤー 役割 必須/任意
PowerShell ブラウザ起動、UI操作、結果抽出、CSV 出力 必須
ブラウザ(Edge等) 社内ポータル表示など 必須
社内ポータル 経費精算の申請状況を参照 必須
Microsoft 365 Copilot / Excel スクリプトの下書き、ファイル出力、ボタン実行、結果確認 任意

365 Copilot (Basic) / (Premium) は、Microsoft Learn でも案内されているアプリ内表示ラベルを指しています。
M365 Copilot は別の AI でも問題ありません。選択できるモデルによっては難易度があがる可能性があります。
本記事は M365 Copilot (Basic) かつ、GPT 5.5 Think Deeper を使って検証しています。

3. 自動化対象システム

対象業務は「経費精算の状況確認」です。
こちらのテスト用に作ったシステムから経理の状況を自動で入手するスクリプトを、AI を使って書いていきます。

👁 経理さいと.png

4. 経理清算状況の確認を自動化

さきほどのサイトを自動で入力していきます。

M365 Copilot Chat で

「UIautomationでコード書いて
要件は以下
https://aaaaabbbbbxxxx.com
これを開いて
申請状況を確認ボタンを押して
2026年6月 経費精算と入力して検索ボタン押して
一番の上の詳細を見るボタンを押す
ステータスを表示を押して
現在のステータスの下にあるステータスを確認してユーザに教える
」

と言った感じで、コードを書いてもらいます。

Python/Selenium 等を提案してくることがあります。使える環境であればそちらでもよいですが、今回は Windows 標準機能だけで紹介していきます。
必要に応じて「Powershellだけで書いてください」といったプロンプトを追加してください。

留意点

システムや要件によっては自動化しない範囲も明確にしておくとよいです。
例えば以下です。

  • ログイン操作
  • MFA 操作
  • 申請・承認・取消・差戻しなどの更新操作

ログインが必要な場合はログイン画面まで来たら待機するスクリプトを AI に書いてもらう等にするとよいと思います。認証情報をスクリプトに持たせないようにするとよいと思います。

5. 実行・修正をループ

  1. コードを PowerShell で実行してみる
  2. 取得結果を確認する
  3. エラーコードやうまくいかない場合は AI に状況を説明して修正してもらう
  4. 要件を満たすまで追加・修正・テストを繰り返す

「最初から全部自動化」をしようとするとだいたい失敗しますので、小さくスタートして徐々に機能を追加していくとよいです。
今回のデモを行う際にも 5 回ほど修正しました。どのボタンが押せていないか、ボタンの位置は○○の近くにあるなど位置情報を伝えながら修正しています。

6. できあがったもの

このようになりました。
以下は自動で動いている様子をGIFにしています。

👁 demo.gif

👁 コンソール画像.png

使用コードは最後に掲載しております。

7. 応用編

上記のように PowerShell を使うことで RPA ができます。
しかし、コードを持ち運ぶのは不便です。
そこで、VBA と組み合わせると運用も楽になります。

具体的には以下のようにします。

  • 出来上がったコードを Excel に貼り付け
  • 実行用の bat ファイルを作ってと AI に依頼 → Excel に記載
  • VBA で Excel にある上記を出力して実行するボタンを作成してと AI に依頼

そうすると Excel 上でコードの一覧と、実行まで完結できるようになります。

8. M365 Copilot (Premium) を使える場合

上記よりもう少し簡単になります。

Excel の Copilot では、チャット経由でワークブックを編集する機能が案内されており、Excel 上のシート内容を見ながら修正指示を出しやすくなっています。コードをセルに保持する構成なら、そのたたき台の修正も進めやすくなります。

また、Microsoft 365 Copilot まわりでは Work IQ という知能レイヤーが案内されており、対象業務システムのマニュアルなどが社内情報として存在する場合、それらを踏まえて調査や下書きを進めやすくなります。
例えば以下のように使用します。

  1. M365 Copilot (Premium) で Copilot Chat の work mode を使い、自動化したい業務に関する社内情報を検索する
  2. 情報を元に自動化方針を固める
  3. 自動化用のコードを書いてもらう

Excel 完結構成のイメージ

たとえば次のような構成です。

要素 役割
PowerShell シート .ps1 に出力したい行を保持する
Batch シート 起動用 .cmd に出力したい行を保持する
結果シート CSV の取込先、ログ確認先にする
VBA ボタン シート内容をファイルに書き出して実行する

この形にすると、Excel 上で Copilot に相談しながら PowerShell やバッチのたたき台を直し、そのままボタン実行まで持っていけます。
つまり、デバッグも試行錯誤も Excel の中で完結しやすくなります。

VBAコードについてもAIに聞けば書いてくれますので、同じ要領で試しながら修正すると完成します。

9. 最後に

制約がある職場でも、AI 活用は十分始められます。
フル自動化でなくても、確認業務だけを切り出した“ちょいRPA”なら、小さく始められます。

コード内容に不安がある場合は、レビューやレビューが大変な場合は専用の Powershell レビューエージェントを作ってレビュー工数を減らす等を検討してもよいかと思います。

あくまで「自動化できている」感が出るという案で、本来は別な方法をとるほうが簡単ですが、まずは AI 活用で価値を見せて次の AI 活用に繋げる。といったボトムアップな切り口の 1 つとして活用するなど必要な方向けに参考になれば幸いです。

思い付きで書いている部分もありますので、何か気になる点等あればぜひコメントで優しく教えていただけますと幸いです。

10. サンプルコード

11. 参考リンク

53

Go to list of users who liked

38
0

Go to list of comments

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
53

Go to list of users who liked

38