国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 web前端 js教程 使用可重用代碼構(gòu)建人工智能驅(qū)動的電子郵件代理

使用可重用代碼構(gòu)建人工智能驅(qū)動的電子郵件代理

Dec 24, 2024 am 08:47 AM

Build an AI-Powered Email Agent with Reusable Code

為什么要自動化您的任務(wù)?

大家好?!作為一名應(yīng)用程序開發(fā)人員,我很高興與您分享如何創(chuàng)建簡單但功能強大的代理來自動執(zhí)行日常任務(wù)。

?和你們許多人一樣,我每天都會收到大量電子郵件。盡管我盡了最大努力,實現(xiàn)難以捉摸的收件箱清零仍然是一個挑戰(zhàn)。整理訂單確認和發(fā)貨更新等電子郵件既乏味又耗時。

但好消息是:自動化可以拯救世界!

?我編寫了一個利用 AI 來幫助自動進行電子郵件分類的基本腳本,您也可以。

在本文中,我將分享可重用的代碼片段,以幫助您構(gòu)建適合您需求的自動化代理。 ?


自動化之美

有無數(shù)的工具,包括無代碼平臺,可以為您處理整個流程。但是,我更喜歡將任務(wù)分解為模塊化代碼片段。為什么?

  1. 靈活性:模塊化代碼可以輕松適應(yīng)不斷變化的需求。
  2. 可重用性:編寫一次,永遠使用。
  3. 可維護性:小而獨立的代碼塊更容易調(diào)試和改進。

通過采取增量方法,您可以逐漸用自動化步驟取代手動步驟。

???我用于制作腳本原型的首選工具是 Znote——一款具有實時編碼和 AI 功能的筆記本,可以幫助我跟蹤和增強我的工作流程。嘗試一下,或者使用您最喜歡的 IDE!


讓我們構(gòu)建一個電子郵件自動化代理

目標

當新電子郵件到達時,我們希望:

  1. 閱讀電子郵件并提取相關(guān)信息。
  2. 使用法學碩士從預(yù)定義列表中確定其類別。
  3. 創(chuàng)建 Gmail 標簽(如果它們尚不存在)。
  4. 更新電子郵件的標簽以反映指定的類別。

入門

先決條件

第 1 步:啟用 Gmail API

  1. 轉(zhuǎn)到 Google Cloud Console 并啟用 Gmail API。
  2. 為桌面應(yīng)用程序設(shè)置 OAuth 憑據(jù)。按照以下步驟下載 google-credentials.json 文件并將其放置在項目目錄中。

第2步:安裝Ollama

下載 Ollama 來運行本地法學碩士。安裝后,下載模型:

ollama pull mistral  

第三步:安裝依賴項

安裝所需的 Node.js 庫:

ollama pull mistral  

編寫代碼

1. 使用Google API進行身份驗證

設(shè)置與 Gmail 的 OAuth 連接:

npm install -S @google-cloud/local-auth googleapis openai  

2. 創(chuàng)建 Gmail 標簽

使用此函數(shù)創(chuàng)建標簽并檢索其 ID:

// google-api.js
const fs = require("fs");
const path = require("path");
const { authenticate } = require("@google-cloud/local-auth");
const { google } = require("googleapis");

class GoogleAPI {
  constructor(credentialFilename) {
    this.TOKEN_PATH = path.join(__dirname, `token-${credentialFilename}`);
    this.CREDENTIALS_PATH = path.join(__dirname, credentialFilename);
    this.SCOPES = [
      "https://mail.google.com/",
      "https://www.googleapis.com/auth/gmail.modify",
    ];
  }

  async authorize() {
    const loadSavedCredentials = () => {
      try {
        const content = fs.readFileSync(this.TOKEN_PATH);
        return google.auth.fromJSON(JSON.parse(content));
      } catch {
        return null;
      }
    };

    const saveCredentials = (client) => {
      const keys = JSON.parse(fs.readFileSync(this.CREDENTIALS_PATH));
      fs.writeFileSync(
        this.TOKEN_PATH,
        JSON.stringify({
          type: "authorized_user",
          client_id: keys.installed.client_id,
          client_secret: keys.installed.client_secret,
          refresh_token: client.credentials.refresh_token,
        })
      );
    };

    let client = await loadSavedCredentials();
    if (!client) {
      client = await authenticate({
        scopes: this.SCOPES,
        keyfilePath: this.CREDENTIALS_PATH,
      });
      if (client.credentials) saveCredentials(client);
    }
    return client;
  }
}

module.exports = GoogleAPI;

3.閱讀電子郵件

從消息 API 中提取詳細信息:

async function createAndGetLabels(labelsToCreate) {
  const google = await getGoogleClient();
  const gmail = google.gmail({ version: "v1" });

  const existingLabels = (await gmail.users.labels.list({ userId: "me" })).data.labels || [];

  const labelsMap = new Map();
  for (const label of labelsToCreate) {
    const existing = existingLabels.find((l) => l.name === label);
    if (existing) {
      labelsMap.set(label, existing.id);
    } else {
      const res = await gmail.users.labels.create({
        userId: "me",
        requestBody: { name: label },
      });
      labelsMap.set(label, res.data.id);
    }
  }
  return labelsMap;
}

4.解密相關(guān)信息

從電子郵件中提取有意義的詳細信息:

async function readEmails(gmail, maxResults = 10) {
  const res = await gmail.users.messages.list({ userId: "me", labelIds: ["INBOX"], maxResults });
  return Promise.all(
    res.data.messages.map(async ({ id }) => {
      const email = await gmail.users.messages.get({ userId: "me", id });
      return email.data;
    })
  );
}

5. 使用法學碩士進行分類

集成 Ollama 或 OpenAI 對電子郵件進行分類:

function extractMailInfos(mail) {
  // Define the headers to extract
  const relevantHeaders = ["Date", "Subject"];

  // Extract and structure the relevant headers
  const headers = mail.payload.headers
    .filter(header => relevantHeaders.includes(header.name))
    .reduce((accumulator, header) => {
      accumulator[header.name] = header.value;
      return accumulator;
    }, {});

  // Add the unique mail ID directly to the headers object
  headers.id = mail.id;

  return headers;
}

把它們放在一起

以下是一切如何協(xié)同工作的:

async function classifyEmail(prompt) {
  const { OpenAI } = require("openai");
  const openai = new OpenAI({ baseURL: "http://127.0.0.1:11434/v1", apiKey: "not-needed" });

  const response = await openai.chat.completions.create({
    model: "mistral",
    temperature: 0.3,
    messages: [{ role: "user", content: prompt }],
  });

  return response.choices[0].message.content.trim();
}

?就是這樣!您的收件箱現(xiàn)在更加智能、更有條理。

走得更遠

但是為什么停在這里呢?探索更高級的示例,用于閱讀電子郵件內(nèi)容、發(fā)送草稿以及構(gòu)建全自動響應(yīng)所需的一切。
有關(guān)更多自動化想法和可重用腳本,請查看 Znote。

讓我們將您的日常任務(wù)變成有趣且高效的事情! ?

以上是使用可重用代碼構(gòu)建人工智能驅(qū)動的電子郵件代理的詳細內(nèi)容。更多信息請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻,版權(quán)歸原作者所有,本站不承擔相應(yīng)法律責任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機

Video Face Swap

Video Face Swap

使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

Java vs. JavaScript:清除混亂 Java vs. JavaScript:清除混亂 Jun 20, 2025 am 12:27 AM

Java和JavaScript是不同的編程語言,各自適用于不同的應(yīng)用場景。Java用于大型企業(yè)和移動應(yīng)用開發(fā),而JavaScript主要用于網(wǎng)頁開發(fā)。

JavaScript評論:簡短說明 JavaScript評論:簡短說明 Jun 19, 2025 am 12:40 AM

JavascriptconcommentsenceenceEncorenceEnterential gransimenting,reading and guidingCodeeXecution.1)單inecommentsareusedforquickexplanations.2)多l(xiāng)inecommentsexplaincomplexlogicorprovideDocumentation.3)

如何在JS中與日期和時間合作? 如何在JS中與日期和時間合作? Jul 01, 2025 am 01:27 AM

JavaScript中的日期和時間處理需注意以下幾點:1.創(chuàng)建Date對象有多種方式,推薦使用ISO格式字符串以保證兼容性;2.獲取和設(shè)置時間信息可用get和set方法,注意月份從0開始;3.手動格式化日期需拼接字符串,也可使用第三方庫;4.處理時區(qū)問題建議使用支持時區(qū)的庫,如Luxon。掌握這些要點能有效避免常見錯誤。

為什么要將標簽放在的底部? 為什么要將標簽放在的底部? Jul 02, 2025 am 01:22 AM

PlacingtagsatthebottomofablogpostorwebpageservespracticalpurposesforSEO,userexperience,anddesign.1.IthelpswithSEObyallowingsearchenginestoaccesskeyword-relevanttagswithoutclutteringthemaincontent.2.Itimprovesuserexperiencebykeepingthefocusonthearticl

JavaScript與Java:開發(fā)人員的全面比較 JavaScript與Java:開發(fā)人員的全面比較 Jun 20, 2025 am 12:21 AM

JavaScriptIspreferredforredforwebdevelverment,而Javaisbetterforlarge-ScalebackendsystystemsandSandAndRoidApps.1)JavascriptexcelcelsincreatingInteractiveWebexperienceswebexperienceswithitswithitsdynamicnnamicnnamicnnamicnnamicnemicnemicnemicnemicnemicnemicnemicnemicnddommanipulation.2)

JavaScript:探索用于高效編碼的數(shù)據(jù)類型 JavaScript:探索用于高效編碼的數(shù)據(jù)類型 Jun 20, 2025 am 12:46 AM

javascripthassevenfundaMentalDatatypes:數(shù)字,弦,布爾值,未定義,null,object和symbol.1)numberSeadUble-eaduble-ecisionFormat,forwidevaluerangesbutbecautious.2)

什么是在DOM中冒泡和捕獲的事件? 什么是在DOM中冒泡和捕獲的事件? Jul 02, 2025 am 01:19 AM

事件捕獲和冒泡是DOM中事件傳播的兩個階段,捕獲是從頂層向下到目標元素,冒泡是從目標元素向上傳播到頂層。1.事件捕獲通過addEventListener的useCapture參數(shù)設(shè)為true實現(xiàn);2.事件冒泡是默認行為,useCapture設(shè)為false或省略;3.可使用event.stopPropagation()阻止事件傳播;4.冒泡支持事件委托,提高動態(tài)內(nèi)容處理效率;5.捕獲可用于提前攔截事件,如日志記錄或錯誤處理。了解這兩個階段有助于精確控制JavaScript響應(yīng)用戶操作的時機和方式。

Java和JavaScript有什么區(qū)別? Java和JavaScript有什么區(qū)別? Jun 17, 2025 am 09:17 AM

Java和JavaScript是不同的編程語言。1.Java是靜態(tài)類型、編譯型語言,適用于企業(yè)應(yīng)用和大型系統(tǒng)。2.JavaScript是動態(tài)類型、解釋型語言,主要用于網(wǎng)頁交互和前端開發(fā)。

See all articles