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

首頁 web前端 js教程 使用可重複使用程式碼建立人工智慧驅(qū)動(dòng)的電子郵件代理

使用可重複使用程式碼建立人工智慧驅(qū)動(dòng)的電子郵件代理

Dec 24, 2024 am 08:47 AM

Build an AI-Powered Email Agent with Reusable Code

為什麼要自動(dòng)化您的任務(wù)?

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

?和你們?cè)S多人一樣,我每天都會(huì)收到大量電子郵件。儘管我盡了最大努力,實(shí)現(xiàn)難以捉摸的收件匣清零仍然是一個(gè)挑戰(zhàn)。整理訂單確認(rèn)和出貨更新等電子郵件既乏味又耗時(shí)。

但好消息是:自動(dòng)化可以拯救世界

?我編寫了一個(gè)利用 AI 來幫助自動(dòng)進(jìn)行電子郵件分類的基本腳本,您也可以。

在本文中,我將分享可重複使用的程式碼片段,以幫助您建立適合您需求的自動(dòng)化代理程式。 ?


自動(dòng)化之美

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

  1. 靈活性:模組化程式碼可以輕鬆適應(yīng)不斷變化的需求。
  2. 可重用性:寫一次,永遠(yuǎn)使用。
  3. 可維護(hù)性:小而獨(dú)立的程式碼區(qū)塊更容易除錯(cuò)和改進(jìn)。

採(cǎi)取增量方法,您可以逐漸以自動(dòng)化步驟取代手動(dòng)步驟。

? ??我用於製作腳本原型的首選工具是 Znote——一款具有即時(shí)編碼和 AI 功能的筆記本,可以幫助我追蹤和增強(qiáng)我的工作流程。嘗試一下,或使用您最喜歡的 IDE!


讓我們建立一個(gè)電子郵件自動(dòng)化代理

目標(biāo)

當(dāng)新電子郵件到達(dá)時(shí),我們希望:

  1. 閱讀電子郵件並擷取相關(guān)資訊。
  2. 使用法學(xué)碩士從預(yù)定義清單中確定其類別。
  3. 建立 Gmail 標(biāo)籤(如果它們尚不存在)。
  4. 更新電子郵件的標(biāo)籤以反映指定的類別。

入門

先決條件

第 1 步:?jiǎn)⒂?Gmail API

  1. 前往 Google Cloud Console 並啟用 Gmail API。
  2. 為桌面應(yīng)用程式設(shè)定 OAuth 憑證。請(qǐng)按照以下步驟下載 google-credentials.json 檔案並將其放置在專案目錄中。

第2步:安裝Ollama

下載 Ollama 來運(yùn)行本地法學(xué)碩士。安裝後,下載模型:

ollama pull mistral  

第三步:安裝依賴項(xiàng)

安裝所需的 Node.js 函式庫(kù):

ollama pull mistral  

編寫程式碼

1. 使用Google API進(jìn)行身份驗(yàn)證

設(shè)定與 Gmail 的 OAuth 連線:

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

2. 建立 Gmail 標(biāo)籤

使用此函數(shù)建立標(biāo)籤並檢索其 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 中提取詳細(xì)資訊:

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)訊息

從電子郵件中提取有意義的詳細(xì)資訊:

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. 使用法學(xué)碩士進(jìn)行分類

整合 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)在更加聰明、更有條理。

走得更遠(yuǎn)

但是為什麼停在這裡呢?探索更高級(jí)的範(fàn)例,用於閱讀電子郵件內(nèi)容、發(fā)送草稿以及建立全自動(dòng)回應(yīng)所需的一切。
有關(guān)更多自動(dòng)化想法和可重複使用腳本,請(qǐng)查看 Znote。

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

以上是使用可重複使用程式碼建立人工智慧驅(qū)動(dòng)的電子郵件代理的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

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

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

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

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

JavaScript評(píng)論:簡(jiǎn)短說明 JavaScript評(píng)論:簡(jiǎn)短說明 Jun 19, 2025 am 12:40 AM

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

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

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

為什麼要將標(biāo)籤放在的底部? 為什麼要將標(biāo)籤放在的底部? 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中事件傳播的兩個(gè)階段,捕獲是從頂層向下到目標(biāo)元素,冒泡是從目標(biāo)元素向上傳播到頂層。 1.事件捕獲通過addEventListener的useCapture參數(shù)設(shè)為true實(shí)現(xiàn);2.事件冒泡是默認(rèn)行為,useCapture設(shè)為false或省略;3.可使用event.stopPropagation()阻止事件傳播;4.冒泡支持事件委託,提高動(dòng)態(tài)內(nèi)容處理效率;5.捕獲可用於提前攔截事件,如日誌記錄或錯(cuò)誤處理。了解這兩個(gè)階段有助於精確控制JavaScript響應(yīng)用戶操作的時(shí)機(jī)和方式。

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是動(dòng)態(tài)類型、解釋型語言,主要用於網(wǎng)頁交互和前端開發(fā)。

See all articles