HOME 首頁
SERVICE 服務(wù)產(chǎn)品
XINMEITI 新媒體代運(yùn)營
CASE 服務(wù)案例
NEWS 熱點(diǎn)資訊
ABOUT 關(guān)于我們
CONTACT 聯(lián)系我們
創(chuàng)意嶺
讓品牌有溫度、有情感
專注品牌策劃15年

    怎么上chatopenai(怎么上插頭)

    發(fā)布時(shí)間:2023-03-12 22:03:35     稿源: 創(chuàng)意嶺    閱讀: 70        問大家

    大家好!今天讓創(chuàng)意嶺的小編來大家介紹下關(guān)于怎么上chatopenai的問題,以下是小編對此問題的歸納整理,讓我們一起來看看吧。

    ChatGPT國內(nèi)免費(fèi)在線使用,能給你生成想要的原創(chuàng)文章、方案、文案、工作計(jì)劃、工作報(bào)告、論文、代碼、作文、做題和對話答疑等等

    你只需要給出你的關(guān)鍵詞,它就能返回你想要的內(nèi)容,越精準(zhǔn),寫出的就越詳細(xì),有微信小程序端、在線網(wǎng)頁版、PC客戶端,官網(wǎng):https://ai.de1919.com

    本文目錄:

    怎么上chatopenai(怎么上插頭)

    一、基于wechaty的定時(shí)消息推送(可以哄女朋友)、智能聊天和私人助理

    ---

    title: "基于wechaty的定時(shí)消息推送(可以哄女朋友)、智能聊天和私人助理"

    author: jasonlovesharon

    email: 54027901@163.com

    tags:

      - nodejs

      - wechaty

      - wechaty-puppet-padplus

    ---

    ## 前言

    - 自從2017年微信web端API限制以后,itchat等一大批bot歇菜了,一直都在找一款合適的替品

    - 目前來看,大部分都是針對windows微信客戶端,基于HOOK的dll注入實(shí)現(xiàn)對微信的操控,有一定的封號(hào)風(fēng)險(xiǎn),只能用固定的版本,部署在linux服務(wù)器端比較困難,意味著只能一直開著電- -wechaty,支持IPAD,,MAC等多種協(xié)議,不用去調(diào)用WEB網(wǎng)頁API,并且可以布署在服務(wù)器,滿足我所有需求。[項(xiàng)目地址](https://github.com/wechaty/wechaty)

    - 看完官方文檔后([token官方介紹](https://github.com/juzibot/welcome/wiki/everything-about-wechaty)), 發(fā)現(xiàn)需要申請Token,并且python版本的Token是要付費(fèi)的,但沒有學(xué)過typescript,有點(diǎn)想放棄,瀏覽了一下ding-dong-bot的Example,似乎可以看懂,那就邊學(xué)習(xí)邊摸索吧。(ps:后來偶然見發(fā)現(xiàn)了另一篇可以使用將token轉(zhuǎn)變一下實(shí)現(xiàn)python版wechaty,但此時(shí)已經(jīng)基本用TS寫完了,如果想用Python等其他語言可以參考[官方文檔](https://github.com/wechaty/wechaty/issues/1985)。)

    ## 具備功能

    ### 1. 關(guān)鍵詞觸發(fā)功能

    1.1 關(guān)鍵詞"介紹一下自己"、 "自我介紹一下"、 "你是誰"觸發(fā)自我介紹

    1.2 地名+天氣 觸發(fā)天氣查詢

    ### 2. 智能聊天功能

    2.1群外直接聊天

    2.2群內(nèi)成員皆有聊天權(quán)限“@bot” 聊天

    2.3不會(huì)回復(fù) @其他群成員 的消息

    ## 實(shí)現(xiàn)過程

    Talk is cheap,show your code

    ### 1. 主程序

    ```typescript

    import { Wechaty, Message, UrlLink,log,} from 'wechaty'

    import { PuppetPadplus } from 'wechaty-puppet-padplus'

    import { EventLogger, QRCodeTerminal } from 'wechaty-plugin-contrib'

    import { WechatyWeixinOpenAI, } from 'wechaty-weixin-openai'

    import { setSchedule, } from './schedule/index'

    import { getDay, formatDate,} from './utils/index'

    import { getOne, getTXweather, getSweetWord,} from './superagent/index'

    // 創(chuàng)建微信每日說定時(shí)任務(wù)

    async function initDay() {

      console.log(`已經(jīng)設(shè)定每日說任務(wù)`);

      setSchedule('0 40 0 * * *', async () => {

        console.log('你的貼心小助理開始工作啦!')

        let logMsg

        let contact =

          (await bot.Contact.find({ name: 'Jason' })) ||

          (await bot.Contact.find({ alias: 'boss' })) // 獲取你要發(fā)送的聯(lián)系人

        let one = await getOne() //獲取每日一句

        let weather = await getTXweather() //獲取天氣信息

        let today = await formatDate(new Date()) //獲取今天的日期

        let memorialDay = getDay('2009/08/07') //獲取紀(jì)念日天數(shù)

        let sweetWord = await getSweetWord()

        let str = `${today}\n我們相愛的第${memorialDay}天\n\n元?dú)鉂M滿的一天開始啦,要開心噢^_^\n\n今日天氣\n${weather.weatherTips}\n${

          weather.todayWeather

        }\n每日一句:<br>${one}<br><br>每日土味情話:<br>${sweetWord}<br><br>————————最愛你的我`

        try {

          logMsg = str

          await delay(2000)

          await contact.say(str) // 發(fā)送消息

        } catch (e) {

          logMsg = e.message

        }

        console.log(logMsg)

      })

    }

    const padplusToken = '你自己的TOKEN'

    const puppet = new PuppetPadplus({

      token: padplusToken,

    })

    const bot = new Wechaty({

      name: 'jason-assistant',

      puppet,

    })

    bot.use(EventLogger())

    bot.use(QRCodeTerminal({ small: true }))

    //在Wechaty里面引用和配置插件

    const openAIToken = '你自己的機(jī)器人TOKEN' //需要在微信對話開放平臺(tái)申請,點(diǎn)擊機(jī)器人設(shè)置》綁定應(yīng)用》在頁面最下方即可看到

    const openAIEncodingAESKey = '你自己的EncodingAESKey' //微信對話開放平臺(tái)申請,點(diǎn)擊機(jī)器人設(shè)置》綁定應(yīng)用》在頁面最下方即可看到

    const preAnswerHook = async (message: Message) => {

      const isCommonMaterial = await processCommonMaterial(message)

      if (isCommonMaterial) {

        return false

      }

    }

    /**

    * 獲得boss聯(lián)系名片,當(dāng)機(jī)器人找不到問題答案時(shí),將BOSS的名片推送過去

    */

    const getBoss = async () => {

        const contact = bot.Contact.load('boss微信ID')

        await contact.sync()

        return contact

      }

      const noAnswerHook = async (message: Message) => {

        const room = message.room()

        const from = message.from()

        if (!room) {

          const boss = await getBoss()

          await message.say('你的問題我不會(huì)回答,你可以聯(lián)系我的老板')

          await message.say(boss)

          return;

        }

        const members = await room.memberAll()

        const bossInRoom = members.find(m => m.id === 'boss微信id')

        if (bossInRoom) {

          await room.say`${bossInRoom},${from}問的問題我不知道,你幫我回答一下吧。`

        } else {

          const boss = await getBoss()

          await room.say`${from},你的問題我不會(huì)回答,你可以聯(lián)系我的老板`

          await room.say(boss)

        }

      }

    /**

    * 用wechaty-weixin-openai可以實(shí)現(xiàn)快速接入微信對話平臺(tái)

    */

    bot.use(WechatyWeixinOpenAI({

        token: openAIToken,

        encodingAESKey: openAIEncodingAESKey,

        noAnswerHook, //在機(jī)器人無法回答時(shí),推送設(shè)定的回答

        preAnswerHook, //判斷是否是關(guān)鍵字,如果是關(guān)鍵字,觸發(fā)關(guān)鍵字回答而不接入微信開放平臺(tái)

      }))

    const processCommonMaterial = async (message: Message) => {

        const room = message.room()

        // const from = message.from()

        const mentionSelf = await message.mentionSelf()

        const text = message.text()

        let intro = 'Jason,愛好廣泛,廣交天下豪杰,上得了九天摘月,下得了五洋捉鱉,俗話說的好,不會(huì)烘培的飛行員不是好戶外人,不會(huì)玩音樂的水族愛好者不是好廚師,不會(huì)畫畫的極限愛好者不是好程序員,這就是我的老板Jason,吼吼吼~~'

        if (room !== null && mentionSelf) {

          if (/jason|你老板|你上司/.test(text)) {

            await room.say(intro)

            await room.say(new UrlLink({

                description: '戶外賤客 & Fighting,fighting,finghting and finghting,讀萬卷書,行萬里路,學(xué)習(xí)AND吃,喝,玩,樂',

                thumbnailUrl: '',

                title: 'Jason',

                url: 'http://mp.weixin.qq.com/s?__biz=MzkxODE3MjAyNQ==&mid=100000001&idx=1&sn=d05de320c6fbe6c9f9149a09a4da81ec&chksm=41b4391776c3b001c143ac2c284c58ac8b08de41d95cab682aa5a07022e32096567f5780d5be#rd',

              }))

            return true

          } else if (/戶外賤客/.test(text)) {

            await room.say(new UrlLink({

                description: '戶外賤客 & Fighting,fighting,finghting and finghting,讀萬卷書,行萬里路,學(xué)習(xí)AND吃,喝,玩,樂',

                thumbnailUrl: '',

                title: 'Jason',

                url: 'http://mp.weixin.qq.com/s?__biz=MzkxODE3MjAyNQ==&mid=100000001&idx=1&sn=d05de320c6fbe6c9f9149a09a4da81ec&chksm=41b4391776c3b001c143ac2c284c58ac8b08de41d95cab682aa5a07022e32096567f5780d5be#rd',

              }))

            return true

          }

        }

        return false

    }

    // 登錄

    async function onLogin(user) {

      console.log(`貼心小助理${user}登錄了`)

      // 登陸后創(chuàng)建定時(shí)任務(wù)

      await initDay()

    }

    bot.on('login', onLogin)

    bot.start()

      .then(() => log.info('StarterBot', 'Starter Bot Started.'))

      .catch(e => log.error('StarterBot', e))

    ```

    ### 2.創(chuàng)建schedule定時(shí)函數(shù)

    ```typescript

    import { schedule } from 'node-schedule'

    // date 參數(shù)

    //其他規(guī)則見 https://www.npmjs.com/package/node-schedule

    // 規(guī)則參數(shù)講解    *代表通配符

    //

    // *  *  *  *  *  *

    // ┬ ┬ ┬ ┬ ┬ ┬

    // │ │ │ │ │  |

    // │ │ │ │ │ └ day of week (0 - 7) (0 or 7 is Sun)

    // │ │ │ │ └───── month (1 - 12)

    // │ │ │ └────────── day of month (1 - 31)

    // │ │ └─────────────── hour (0 - 23)

    // │ └──────────────────── minute (0 - 59)

    // └───────────────────────── second (0 - 59, OPTIONAL)

    // 每分鐘的第30秒觸發(fā): '30 * * * * *'

    //

    // 每小時(shí)的1分30秒觸發(fā) :'30 1 * * * *'

    //

    // 每天的凌晨1點(diǎn)1分30秒觸發(fā) :'30 1 1 * * *'

    //

    // 每月的1日1點(diǎn)1分30秒觸發(fā) :'30 1 1 1 * *'

    //

    // 每周1的1點(diǎn)1分30秒觸發(fā) :'30 1 1 * * 1'

    function setSchedule(date,callback) {

      schedule.scheduleJob(date, callback)

    }

    export function setSchedule()

    ```

    ### 3.創(chuàng)建幾個(gè)功能函數(shù),爬取ONE網(wǎng)站的每日一句,提取通過API獲取的消息

    ```typescript

    import * as cheerio from 'cheerio'

    import * as superagent from 'superagent'

    const ONE = 'http://wufazhuce.com/' // ONE的web版網(wǎng)站

    const TXHOST = 'http://api.tianapi.com/txapi/' // 天行host

    function req(url,method, params, data, cookies) {

      return new Promise(function (resolve,reject) {

        superagent(method, url)

          .query(params)

          .send(data)

          .set('Content-Type','application/x-www-form-urlencoded')

          .end(function (err, response) {

            if (err) {

            reject(err)

            }

            resolve(response)

          })

        })

    }

    async function getOne() {

      // 獲取每日一句

      try {

        let res = await req(ONE, 'GET')

        let $ = cheerio.load(res.text)

        let todayOneList = $('#carousel-one .carousel-inner .item')

        let todayOne = $(todayOneList[0])

          .find('.fp-one-cita')

          .text()

          .replace(/(^\s*)|(\s*$)/g, '')

        return todayOne

      } catch (err) {

        console.log('錯(cuò)誤', err)

        return err

      }

    }

    async function getTXweather() {

      // 獲取天行天氣

      let url = TXHOST + 'tianqi/'

      try {

        let res = await req(url, 'GET', {

          key: '你自己的KEY',//需要自己去天行申請,地址https://www.tianapi.com/signup.html?source=474284281

          city: 'Arlington'

        })

        let content = JSON.parse(res.text)

        if (content.code === 200) {

          let todayInfo = content.newslist[0]

          let obj = {

            weatherTips: todayInfo.tips,

            todayWeather:`阿林頓今天${todayInfo.weather}\n溫度:${todayInfo.lowest}/${todayInfo.highest}

            \n${todayInfo.wind}風(fēng): ${todayInfo.windspeed}\n紫外線指數(shù):${todayInfo.uv_index}\n濕度

            ${todayInfo.humidity}`

          };

          console.log('獲取天行天氣成功', obj)

          return obj

        } else {

          console.log('獲取接口失敗', content.code)

        }

      } catch (err) {

        console.log('獲取接口失敗', err)

      }

    }

    async function getSweetWord() {

      // 獲取土味情話

      let url = TXHOST + 'saylove/'

      try {

        let res = await req(url, 'GET', { key: '' })

        let content = JSON.parse(res.text)

        if (content.code === 200) {

          let sweet = content.newslist[0].content

          let str = sweet.replace('\r\n', '<br>')

          return str

        } else {

          console.log('獲取接口失敗', content.msg)

        }

      } catch (err) {

        console.log('獲取接口失敗', err)

      }

    }

    export { getOne, getTXweather, getSweetWord, }

    ```

    ### 計(jì)算距離某日(生日,結(jié)婚紀(jì)念日等)還有多少天

    ```typescript

    function getDay(date) {

      var date2 = new Date()

      var date1 = new Date(date)

      var iDays = parseInt(

        Math.abs(date2.getTime() - date1.getTime()) / 1000 / 60 / 60 / 24

      )

      return iDays

    }

    function formatDate(date) {

      var tempDate = new Date(date)

      var year = tempDate.getFullYear()

      var month = tempDate.getMonth() + 1

      var day = tempDate.getDate()

      var hour = tempDate.getHours()

      var min = tempDate.getMinutes()

      var second = tempDate.getSeconds()

      var week = tempDate.getDay()

      var str = ''

      if (week === 0) {

        str = '星期日'

      } else if (week === 1) {

        str = '星期一'

      } else if (week === 2) {

        str = '星期二'

      } else if (week === 3) {

        str = '星期三'

      } else if (week === 4) {

        str = '星期四'

      } else if (week === 5) {

        str = '星期五'

      } else if (week === 6) {

        str = '星期六'

      }

      if (hour < 10) {

        hour = '0' + hour

      }

      if (min < 10) {

        min = '0' + min

      }

      if (second < 10) {

        second = '0' + second

      }

      return year + '-' + month + '-' + day + '日 ' + hour + ':' + min + ' ' + str

    }

    export { getDay, formatDate }

    ```

    ![關(guān)鍵字觸發(fā)消息](https://wechaty.js.org/assets/2020/daily-message-and-chatbot/keyword-push.png)

    ![無法回答推送名片](https://wechaty.js.org/assets/2020/daily-message-and-chatbot/push-contact.png)

    ![定時(shí)推送消息](https://wechaty.js.org/assets/2020/daily-message-and-chatbot/daily-message.png)

    ![智能聊天](https://wechaty.js.org/assets/2020/daily-message-and-chatbot/talk-to-bot.png)

    ## 后記

    到此已經(jīng)實(shí)現(xiàn)了私人人助理和定時(shí)推送消息的功能([項(xiàng)目地址](https://github.com/jasonlovesharon/my_bot)),由于對Typescript不熟,很多功能都是借鑒很多大神的輪子實(shí)現(xiàn)的,還是對Python熟悉點(diǎn),下步準(zhǔn)備用Python來實(shí)現(xiàn)以上功能,并進(jìn)一步拓展更多有趣的功能。

    二、chatgpt美國能用嗎

    美國可以使用ChatGPT,但是要注意使用范圍。ChatGPT是一款基于聊天機(jī)器人技術(shù)的軟件,可以幫助用戶解決許多問題,比如技術(shù)支持、客戶服務(wù)、技術(shù)咨詢等。它可以根據(jù)用戶提供的關(guān)鍵詞,快速搜索出相關(guān)信息,幫助用戶快速解決問題。但是,由于ChatGPT是一款國外的軟件,在美國使用時(shí),需要符合美國的法律法規(guī),以及相關(guān)的隱私權(quán)和安全要求。因此,在使用ChatGPT之前,建議用戶先仔細(xì)閱讀相關(guān)規(guī)定,以確保自身的安全和隱私權(quán)。

    三、chatg中文版怎么下載正版

    在“蘿卜家園”下載。

    chatg中文版可以在“蘿卜家園”下載,網(wǎng)頁搜索“蘿卜家園”,進(jìn)入首頁搜索“chatg中文版”即可。

    chatg中文版下載步驟:1、下載插件,復(fù)制官網(wǎng)鏈接,點(diǎn)擊Chrome瀏覽器搜索即可。2、在右上角打開【開發(fā)者模式】,選擇【加載已解壓的擴(kuò)展程序】。3、第二步選擇解壓的文件夾,回到ChatGPT,打開 search on the Web。

    四、中國如何缺席chatgpt

    技術(shù)上的原因:ChatGPT是由OpenAI公司開發(fā)的,OpenAI是由一些硅谷科技巨頭和投資者支持的非營利組織。這意味著中國企業(yè)和科學(xué)家無法直接獲得ChatGPT的技術(shù)和算法,需要進(jìn)行技術(shù)合作或者自主研發(fā)。

    市場原因:ChatGPT主要是為英語和西方用戶開發(fā)的,中國市場需要更多針對中文和中國文化的自然語言處理技術(shù)。由于語言和文化的差異,ChatGPT可能需要進(jìn)行大量的本地化調(diào)整才能適應(yīng)中國市場的需求。

    政策原因:中國政府對互聯(lián)網(wǎng)和科技領(lǐng)域的監(jiān)管越來越嚴(yán)格,包括對數(shù)據(jù)隱私和安全的

    以上就是關(guān)于怎么上chatopenai相關(guān)問題的回答。希望能幫到你,如有更多相關(guān)問題,您也可以聯(lián)系我們的客服進(jìn)行咨詢,客服也會(huì)為您講解更多精彩的知識(shí)和內(nèi)容。


    推薦閱讀:

    中俄跨境電商平臺(tái)有哪些(亞馬遜電商平臺(tái)怎么入駐要多少錢)

    ypa景觀設(shè)計(jì)(ypa景觀設(shè)計(jì)有限公司怎么樣)

    直播被警告是有人舉報(bào)嗎(直播被警告是有人舉報(bào)嗎怎么辦)

    鄭州產(chǎn)品設(shè)計(jì)公司

    體現(xiàn)空間感的畫(體現(xiàn)空間感的畫有顏色)