はじめに
2025 年 3 月27 日に Microsoft の AI Tour が東京でありました。そちらにて、改めて、Copilot Studio に対する注目度の高さ、期待の大きさを感じました。
最近以下の記事にも書きましたが、最近の Copilot Studio の熱い機能は、自律型エージェントです。
これまで Copilot Studio で作成できたのは、従来型チャットボット (Power Virtual Agents 時代)、生成 AI チャットボット (初期 Copilot Studio)等であり、入口はチャットでした。
自律型エージェントは、チャットベースで動作するものではなく、Power Automate のトリガーやアクション、公開 Web サイト、SharePoint サイト、ファイルのアップロード、Dataverse、その他のデータベースやサービスなど、さまざまなナレッジを組み合わせて、うまくオーケストレーションしてくれるものだと思います。
その結果、より人間のアシスタントに近い形で、業務を代行してくれるエージェントを構築できるイメージでしょうか。
こちらを踏まえ、改めてどのようなことができそうかを検証してみます。
私の検証方法や指示の書き方に課題があるのかもしれませんし、現時点では日本語が厳密にはサポートされていないという認識もあるため、うまく動作しなかったケースもすくなからずあります。
それでも、この自律型エージェントの今後の機能進化により、AI が人間の役割を担える領域は大きく広がっていくと確信しています。
そこで今回は、あくまで個人的な意見にはなりますが、自律型エージェントを作成する上でのポイントや、今後この領域が進化すればより実用的になると感じる点等について、整理してみたいと思います。
また、この記事を書くことで、同じ関心を持つ方々から情報が集まることも、少し期待しています。
トリガー
Copilot Studio では、Power Automate のようにトリガーを指定できるようになりました。こちらにより、チャットをしなくても自動で動き出すエージェントを作成できるようになります。
※ 記事執筆時点では 44 件のトリガーが利用できるようです。今後更に増えると思いますが、現時点でもそれなりのことはできそうです
トリガーを追加すると、Power Automate の画面が立ち上がり、こんな感じで、いつものように Power Automate のフローを作成し、Copilot Studio のプロンプトを呼ぶ感じになります。
こちらを利用することで、例えば、スケジュールトリガーで、動き出し、ナレッジに追加している Web サイトから最新の情報を検索して、結果を通知するようなエージェントを作成できそうと考えました。
個人的に、定期的に、Web サイトから最新の情報を取得して社内向けにニュースレターを出すような業務あると思います。これらの業務を自動化する際、以下のようなアプローチが考えられますが、いずれに関しても難しいというケースもそれなりにあるという認識です。
-
RSS の対応してれば Power Automate で自動化
※ただし、RSS で取得できる情報は限られる認識 -
API で情報取得できる場合は Power Automate で自動化
-
RPA で定期的に Web サイトを訪問して情報を取得
※ロボットでの操作を禁止している場合があるため、注意が必要
そのため、Copilot Studio でいい感じにナレッジから最新の情報を取得して、アクションで通知したり DB に保存をしてくれたりしたら非常に助かるケースもあると思います。
試しに、以下のように最新の生成 AI に関する情報を取得するようなエージェントを作成してみました。
今回チャレンジポイントは、エージェントを動かした日の前日に公開された記事のみ取得することです。
指示文に関数が入れるため、関数を入れたり、トリガーからエージェントを呼ぶ際に前日の日付を入れてみました。
しかし、トリガーのテストをしてみると、ナレッジから比較的最近の記事を取得できているのですが、前日公開された以外の記事が沢山返されてしまいます。
こちらは、ナレッジの Web サイト上の情報検索結果、つまりインデックスのクオリティに影響されるため、個人的には「ピンポイントで、トリガーを実行した日の前日に公開された記事のみを取得する」といったことは、そう簡単ではないと感じています。
ただし、検証を重ねていると、上手く、公開日を基に情報を取得できてそうな時もありました。
※以下は、2025-3-19 の日付にして検証
なお、こちらのブログ記事は上手く取得できていませんでした。この辺は Web サイトに対する検索との相性もあると思います。
最終的にどのようなキーワードで検索しているかは分かりませんが、試しに、私のブログの記事に対して、日付の情報を添えて検索すると、検索結果が返ってきませんでした。そのため、上手く情報が見つからないのかもしれません。
この辺について、もう少しナレッジのパートで深堀しようと思いますが、質問をしてナレッジから回答をすることだけではなく、こういった用途で、情報の公開日を基に記事を取得できるようになると、Copilot Studio で作成するエージェントの活用が広がると思います。
アクション
Copilot Studio では、各種アクションを追加できます。分かりやすいところでいうと、Power Automate で作成したフローやコネクタのアクションです。そのため、複数のアクションを追加して、臨機応変に呼び出させるようなことが可能です。
ご存じの人も多いと思いますが、Power Automate のフローやコネクタでは、様々なクラウドサービスと連携をすることができます。そのため、これにより、エージェントができることが大幅に広がります。
とりあえず、ナレッジから取得した最新情報を受け取って通知をする簡易的なフローを作成してアクションに追加しました。
アクションを呼び出す方法は指示に書いています。
トリガーのテストを実行してみると、上手く実行されたようです。ただ、たまに呼ばれないときもありました。
また、アクションが複数になるなど、もっと複雑な構成になった際、上手く柔軟に呼び出してくれるか、上手く入力を渡してくれるかなど、引き続き検証が必要かなと思っています。
ナレッジ
トリガーやアクションを構成できることで自律型のエージェントの作成ができるようになりましたが、やはり、Copilot Studio の肝は、ナレッジから期待する情報を取得できるかだと思います。
また、以下の記事で言及したように、ロジック化、つまり、条件分岐などを組み合わせてプログラム化が難しい大量のナレッジから情報を取得できることが Copilot Studio の強みというか、Copilot Studio で作成する理由になると思っています。
現状、ナレッジとして追加できるソースは以下のような感じです。恐らく、最も手軽に追加できるのは、公開 Web サイト、SharePoint、ファイルのアップロードあたりだと思います。それぞれのポイントを整理してみたいと思います。
公開 Web サイト
公開 Web サイトを追加してそちらのサイト内の情報から回答を得ることができます。こちらは鉄板ですね。
個人的には、階層の深さが 2 階層以下までのため、例えば、以下のようなリンクは追加できません。個人的にはもう少し深い階層まで追加できると嬉しいです。
なお、最近追加された以下の箇所について、どういう時にチェックを入れる、トグルをオンにするべきか、そうすることでどのように挙動が変わるのか、情報を確認できませんでした。
また、回答の精度に関しては、上述の通り、Web サイトのページに対する検索結果が影響します。つまり、インデックスのクオリティの影響を受けると思います。そのため、Copilot Studio 側だけではハンドリングが難しい部分もあります。
しかし、個人的には、演算子を上手く使うことで、微調整はできそうな気がしております。
ChatGPT に聞いてみたところ、Bing 検索では、以下のような演算子が使えるようです。これらを使って、該当の Web サイトで取得したい情報を得るための精度が高い検索手法を調べていくのがよいかと思います。
例えば、該当のサイト内で情報を取得したい箇所の URL に「news」が含まれ、新しい記事に「新着や new」といったワードが含まれる場合、以下のように検索するよう指示する感じです。
site:サイト名 inurl:news 新着 OR new
演算子 | 意味 | 使用例 | 備考 |
---|---|---|---|
site: |
特定のサイト内検索 | site:qiita.com Power Apps |
サブドメインも対象に含まれる |
intitle: |
タイトルに含まれる | intitle:Power Apps |
Bingでは部分一致で使える |
inurl: |
URLに含まれる | inurl:PowerApps |
特定カテゴリなどの抽出に便利 |
filetype: |
指定のファイル形式 | filetype:pdf Power Platform |
PDF, DOCX, PPT など |
OR |
いずれかを含む | "Power Apps" OR "Power Automate" |
複数語をカバー |
AND |
両方を含む(省略可能) | "Power Apps" AND "初心者" |
ANDは省略してもAND検索になる |
- (ハイフン) |
特定語を除外 | Power Apps -Dynamics |
除外フィルター |
" (ダブルクォート) |
完全一致のフレーズ検索 | "Power Apps 入門" |
複数語をまとめて検索 |
define: |
用語の定義を検索 | define:Power Platform |
英語では有効、日本語では弱め |
なお、上記には記載していませんが、after:
演算子を使うと、上述のケースにて、指定した指定した日付以降に更新された記事のみ取得する精度が上がると考えました。
しかし、Bing の場合は、after:
を使っても古い記事が出てしまいました。
なお、試しに、Google で以下のようにすると、指定した日付以降に更新された記事のみ取得できました。bing でも Google のように指定した日付以降に更新された記事のみ取得できると嬉しいです。
site:qiita.com/Takashi_Masumori after:2025-03-18
いずれにせよ、この辺を試行錯誤することで少なからず調整ができそうなため、例えば、指示やトリガーから渡す情報にも演算子を入れてみるのはありかもと思います。
SharePoint サイト
SharePoint サイト、フォルダー、ファイル等を直接指定できるため、既に SharePoint を利用していてナレッジが蓄積している場合は、そちらのサイトやフォルダーを指定するだけでいいので楽です。
複数のファイルがある場合、フォルダー等を指定すればいいので、メンテナンスも楽です。
サイト全体を指定する場合を含め、以下のような管理を行っていると、回答の精度が低下する可能性があるため、注意が必要です。
-
ファイル名が「doc1.pdf」「newfile_final2.docx」など、ファイル名からどのような情報が記載されているか分からないファイル
-
複数のテーマが混在した巨大な Word ファイル
-
古い版と新しい版がサイト内に沢山ある
-
パスワード付きやアクセス制限があるファイル
また、SharePoint サイトを指定している際は、Microsoft 365 Copilot のライセンスを保有していると、検索精度が向上します。そのため、Microsoft 365 Copilot のライセンスを保有している場合、こちらをオンにして試してみることをお勧めします。
ファイルアップロード
ファイルを直接アップロードしてナレッジを追加できます。個人的に、こちらの機能、インデックス精度が高くお勧めです。
少数のファイルであり、変更が少ないファイルであればこちらの機能を使えるのですが、ファイルが多数ある、変更もそれなりにある場合、メンテナンスが大変という難点があります。
こちらの対策として、以下の方法を以前記事に書いてますので、興味がある方は読んでみてください。
Dataverse テーブル
ナレッジとして Dataverse テーブルも追加できます。
既に Power Apps でアプリを作って運用しており Dataverse にナレッジがある場合はそのまま使えますし、 他のデータベースにデータを既に持っている場合、そちらのデータを Datavese にデータフローで移すこともできますし、今後 Dataverse にデータをためていくことで、Copilot Studio のナレッジとして有効活用できるため、個人的にこちらの機能に注目しています。
現状プレビュー機能であり、日本語の検索精度に課題があると感じています。ただし、今後 Dataverse のインデックス精度が向上すれば、かなり活用されるようになると考えています。そのため、今のうちに Dataverse にデータを蓄積して、こちらの機能を試してみることをお勧めします。
指示
生成 AI 機能を活用する上で、指示文に記載する内容は非常に重要です。どのようなタイミングでアクションを呼び出すのか、アクションにどのような情報を渡すのかなど、正確に記述する必要があると認識しています。
エージェントの精度を高めるための指示の書き方については、ChatGPT や Copilot にプロンプトを入力する際のコツとどう異なるのか、現時点分かりませんが、今後何か分かったら、本記事に追記するか、別の記事としてまとめる予定です。
まとめ
Copilot Studio の自律型エージェント作成機能を試してみました。その上で、自律型エージェントを構築する際のポイントや、今後ここが進化すればさらに実用性が高まると感じた点を整理してみました。
特に今後の日本語対応の強化や、インデックス機能の進化には大きな期待を寄せています。引き続き、日々試行錯誤しながら、具体的なユースケースの可能性も模索していきたいと思います。