分享方式:


傳回結果的清單

要求代理程式在外部系統中尋找資料並傳回結果清單是很常見的。 為此,代理程式可以呼叫 Power Automate 流程來執行以下操作:

  1. 進行驗證並連接到外部解決方案。
  2. 根據使用者輸入執行查詢。
  3. 格式化結果。
  4. 將結果傳回給代理程式。

此範例使用 Power Automate 中的 Dataverse 連接器來搜尋帳戶。 連接器會向您的代理程式傳回包含帳戶名稱、城市和帳號的結果清單。

必要條件

設定 Dataverse 會計資料表

帳戶表是 Power Platform 環境中預設可用的標準表。 但是,這不附帳戶資料。 在您的代理程式可以搜尋帳戶之前,您必須填入帳戶表。

如果您已經有含資料的帳戶表格,請略過此步驟,並繼續建立主題。 但是,請記住在後續步驟中測試代理程式時使用與您的資料相關的搜尋字詞。

  1. 前往 Power Apps 入口網站

  2. 在導覽窗格中,選擇資料表

  3. 選擇帳戶資料表,然後在資料表屬性頁面上,選擇編輯

  4. 將以下行新增到資料表中:

    位址 1:市/鎮 帳戶名稱 帳戶
    西雅圖 Contoso Inc AC0125
    舊金山 Contoso Residences AC0255
    Olympia Contoso 餐飲交貨 AC0035

建立主題

  1. 在 Copilot Studio 中,前往您的代理程式的主題頁面。

  2. 建立一個名為帳戶搜尋的主題。

  3. 新增下列觸發字詞:

    • 我正在尋找客戶
    • 我正在尋找帳戶
    • 搜尋帳戶
    • 搜尋客戶
  4. 新增一個訊息節點並輸入訊息「聽起來您正在尋找一個帳戶。 我可以幫您查一下。」

  5. 新增一個問題節點並輸入訊息「您正在尋找的客戶叫什麼名字?」

  6. 如需確認,選取組織

    使用者的完整回應也將有效。 但是,透過選擇組織實體,您可以利用代理程式的語言理解能力從回應中提取組織名稱。

  7. 對於將使用者回應另存為,將變數重新命名為「組織」。

    帶有訊息節點和問題節點的「帳戶搜尋」主題的螢幕擷取畫面。

建立流程

  1. 選擇任意節點下方的新增節點圖示,然後選擇新增動作

  2. 基本動作標籤上,選擇新 Power Automate 流程

  3. 在 Power Automate 中,選擇流程的名稱並將其替換為搜尋帳戶

  4. 選擇從 Copilot 執行流程流程觸發程序,並新增名為 Organization文字輸入參數。

    帶有「組織」文字輸入的流程觸發程序的螢幕擷取畫面。

  5. 選擇從 Copilot 執行流程流程觸發程序下方的新增圖示。

  6. 新增動作中,搜尋「Microsoft Dataverse」,然後選擇搜尋資料行動作。

    此動作會使用模糊比對,在您 Dataverse的帳戶表格 中尋找相關的帳戶。

  7. 搜尋詞框中,輸入斜線 (/),選擇插入動態內容,然後選擇您的組織輸入參數。

  8. 對於進階參數,選擇顯示全部並設定以下值:

    • 資料表篩選項目account
    • 依項目排序 - 1search.score desc
    • 依項目排序 - 2name asc

    具有進階選項的「搜尋行」動作屬性的螢幕擷取畫面。

格式化結果

搜尋列動作會傳回資料列清單變數,其中包含 JSON 資料。 在使用資料之前,您必須使用解析 JSON 動作對其進行分析。

  1. 選擇搜尋資料行動作下方的新增圖示。

  2. 新增動作中,搜尋「資料動作」,然後選擇解析 JSON動作。

  3. 內容方塊中,輸入斜線 (/),選擇插入動態內容,然後選擇資料行清單

  4. 複製下列 JSON 結構描述,並將其貼到結構描述方塊中:

    {
        "type": "array",
        "items": {
            "type": "object",
            "properties": {
                "@@search.score": {
                    "type": "number"
                },
                "name": {
                    "type": "string"
                },
                "address1_city": {
                    "type": "string"
                },
                "accountnumber": {
                    "type": "string"
                }
            },
            "required": [
                "name"
            ]
        }
    }
    

    解析 JSON 動作屬性中的 JSON 模式的螢幕擷取畫面。

  5. 選擇解析 JSON 動作下方的新增圖示。

  6. 新增動作中,搜尋「變數」,然後選擇初始化變數動作。

  7. 名稱方塊中,輸入「ListOfAccounts」。

  8. 類型選取字串

    「初始化變數」動作屬性的螢幕擷取畫面。

  9. 選擇初始化變數動作下方的新增圖示。

  10. 新增動作中,搜尋「控制」,然後選擇套用至每個動作。

  11. 從前面的步驟中選擇一個輸出方塊中,輸入斜線 (/),選擇插入動態內容,然後選擇分析 JSON 下的正文變數。

  12. 選擇套用至每個動作新增圖示。

  13. 新增動作中,搜尋「變數」,然後選擇附加到字串變數動作。

  14. 名稱選取 ListOfAccounts

  15. 複製下列文字,並在方塊中將其貼上:

    - @{items('Apply_to_each')['accountnumber']}: @{items('Apply_to_each')['name']} - @{items('Apply_to_each')['address1_city']}
    
  16. 在程式碼片段後面新增分行符號,讓每個結果顯示在自己的行上。

    「附加到字串變數」動作屬性的螢幕擷取畫面。

  17. 回應 Copilot 動作中,加入文字輸出。

  18. 對於名稱,輸入「FoundAccounts」。

  19. 對於值,在方塊中輸入斜線 (/),選擇插入動態內容,然後選擇 ListOfAccounts 變數。

    「回應 Copilot」動作屬性的螢幕擷取畫面。

  20. 儲存並發佈您的流程。

從 Copilot Studio 呼叫流程

  1. 在 Copilot Studio 中,選擇問題節點下的新增節點圖示,選擇新增動作,然後選擇您先前建立的流程搜尋帳戶

  2. 將流程輸入參數設定為來自問題節點的輸出變數:組織 (字串)組織變數取得其值。

  3. 新增一個訊息節點並輸入訊息「好的,這是我發現的。」

  4. 新增第二個訊息節點。 選擇插入變數圖示,然後選擇 FoundAccounts

    使用找到的帳戶清單進行回應的對話流程的螢幕擷取畫面。

  5. 選取儲存

  6. 測試您的代理程式。

    測試面板中範例對話的螢幕擷取畫面。