ChatGPT实战-构建文章分析AI聊天机器人

视频版本:

ChatGPT实战-构建文章分析AI聊天机器人

简介

本文实现如下功能:

当浏览一篇文章,点击分享,分享到聊天软件的对话框中。它就会生成一个文章的总结和分析结果。例如分析是否有逻辑问题,是否有诱导购买,是否有焦虑制造。

一起来看看怎么实现的吧。

这里以飞书机器人为例,当然你也可以用别的平台,例如微信、钉钉。

整体方案介绍

方案

  1. 首先,用户将文章链接发送给飞书聊天机器人;
  2. 飞书通过事件订阅将内容发给机器人服务端;
  3. 服务端收到链接后访问网址获取内容,并调用chatgpt接口进行总结;
  4. 将总结后的内容回复给用户。

下面我们来一步步实现。

前置准备

在开始之,你需要准备好ChatGPT的API访问key和一台web服务器。

准备web服务器的时候,需要注意安全问题。例如服务器关闭root登录,禁止密码登录。采用ssh key的方式进行登录。

然后防火墙需要在云厂商的控制台开启。不然外部无法访问。

代码

在github中也可以找到:shanchuantian/paper_analyze_bot.git
有三个文件,入口在main.py中。
main.py

import json
import uuidimport requests
from fastapi import FastAPI
from fastapi.params import Body
from fastapi import BackgroundTasksfrom openai import chat
from parse_wexin_paper import get_paper_contentapp = FastAPI()@app.get("/")
def root():return {"message": "Hello World"}def get_tenant_access_token():url = 'https://open.feishu.cn/open-apis/auth/v3/app_access_token/internal'body = {"app_id": "cli_xxx",  # todo 可以将其放入环境变量中,不能泄漏!!!!"app_secret": "jwxxx"  # todo 可以将其放入环境变量中,不能泄漏!!!!}res = requests.post(url, json=body)return res.json().get('tenant_access_token')def send_response(message_id, text_content):# 回复消息url = f'https://open.feishu.cn/open-apis/im/v1/messages/{message_id}/reply'res_content = {"text": text_content}response = {"content": json.dumps(res_content),"msg_type": "text","uuid": str(uuid.uuid4())}token = get_tenant_access_token()headers = {'Authorization': f'Bearer {token}','Content-Type': f'application/json; charset=utf-8'}print(f'response url:{url}, header:{headers}, data:{response}')requests.post(url, headers=headers, json=response)def handle_task(payload):# 用户发过来的消息content = payload.get('event').get('message').get('content')print(f'content:{content}')# 获取文章内容paper_content = get_paper_content(json.loads(content).get('text'))prompt = f"""我会给你一篇由<<begin>>和<<end>>包含的文章,请完成如下任务:1.总结一下文章,以列表的形式输出关键要点,保持语句通顺,简单易懂。2.分析文章中是否有逻辑问题,如果有请依次列出问题,写在下面的【逻辑问题列表】中,没有则保持空。3.分析文章中是否有诱导读者购买课程、商品等行为,如果有请写在下面的【诱导购买列表】中,没有则保持空。4.分析文章中是否有焦虑制造倾向,如果有请写在下面的【焦虑制造列表】中,没有则保持空。严格按照如下格式输出:【总结】这里放总结内容。【逻辑问题列表】在这里列出逻辑问题。【诱导购买列表】在这里列出诱导购买内容。【焦虑制造列表】在这里放焦虑制造内容。这是文章:<<begin>>{paper_content}<<end>>"""print(f'prompt:{prompt}')# 调用ChatGPT进行总结summary = chat(prompt)message_id = payload.get('event').get('message').get('message_id')# 回复消息send_response(message_id, summary)@app.post("/")
async def say_hello(background_tasks: BackgroundTasks, payload: dict = Body(...)):# 检测到CHALLENGE标记就直接返回,以通过飞书的接入challenge = payload.get('CHALLENGE')if challenge:print(f'CHALLENGE flag is exist, return it.')return payload# print(f'payload:{json.dumps(payload)}')# feishu要求1秒内返回,所以此处起一个后台任务处理background_tasks.add_task(handle_task, payload)print('###### i will return immediately。。。')return ''if __name__ == '__main__':get_tenant_access_token()

openai.py

import requestsurl = "https://openai.api2d.net/v1/chat/completions"headers = {'Content-Type': 'application/json',# todo 不能泄漏'Authorization': 'Bearer fkxxx' # <-- 把 fkxxxxx 替换成你自己的 Forward Key,注意前面的 Bearer 要保留,并且和 Key 中间有一个空格。
}def chat(content, role='user', model='gpt-3.5-turbo'):data = {"model": model,"messages": [{"role": role, "content": content}]}print('start chat to chatgpt....')response = requests.post(url, headers=headers, json=data)print("ChatGPT Status Code", response.status_code)print("ChatGPT JSON Response ", response.json())return response.json().get('choices')[0].get('message').get('content')if __name__ == '__main__':content = '你好'chat(content=content)

parse_wexin_paper.py

import requests
from lxml import etree
import osdef get_paper_content(url):html = requests.get(url).text# print(f'html:{html}')con = etree.HTML(html)# 获取标题h2 = con.xpath('//h1[@class="rich_media_title "]/text()')h2 = ",".join(map(str, h2))h2 = os.linesep.join([s for s in h2.splitlines(True) if s.strip()])h2 = h2.rstrip()  # 去除右空行print(f'h2:{h2}')# print(h2)# 获取正文p_text = ''span = con.xpath('//p | //section/span')  # 通过‘|’可以增加筛选的条件print(f'span:{span}')# print(span)for p_tex in span:p_tex = p_tex.xpath('string(.)')p_text = p_text + p_tex + '\n'# print(p_tex)# print(p_text)# 保存内容con_text = '%s%s%s%s' % (h2, '\n', p_text, '\n')return con_textif __name__ == '__main__':# url = input("请输入要采集的微信公众号文章地址:")url = "https://mp.weixin.qq.com/s/xxx"get_paper_content(url)

我们通过fast API这个web框架来实现web服务。在这里我们需要实现两个功能:

一个是接入服务功能,另一个是我们的业务逻辑。

运行服务可以直接通过uvicorn 运行:

uvicorn main:app --host 0.0.0.0 --port 7011

飞书权限申请

主要是在飞书开放平台申请应用,然后添加权限,事件订阅发布版本。(截图太多了,上面视频中有详细介绍)

接下来就可以愉快的进行使用啦。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/84474.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

常用的Spring Boot注解及其作用

Spring Boot是一个用于简化Java应用程序开发的框架&#xff0c;它提供了许多注解来简化开发和配置应用程序。这些注解能够帮助开发者减少重复的劳动&#xff0c;并提高开发效率。下面将详细介绍一些常用的Spring Boot注解及其作用。 1. SpringBootApplication注解 是一个复合…

Fiddler 八个实用技巧

大家对Fiddler应该不会陌生&#xff0c;但里面有些技巧不见得都会&#xff0c;这里就有八个实用技巧&#xff0c;通过对Fiddler的定制&#xff0c;能提高大家的测试效率。 1、双击Session时&#xff0c;使响应页始终显示到”json”tab页&#xff1b;使请求页始终显示到“webfo…

中科院预警名单

2023年预警名单 (fenqubiao.com) 如果论文投稿到中国科学院预警期刊,可能会面临以下情况: 1. 预警期刊一般审稿周期长,容易出现迟迟不见回音的情况。 2. 这类期刊的学术质量参差不齐,接受论文的学术标准可能不严格。 3. 预警期刊发表论文的学术影响力比较有限,不容易为作者…

【操作系统】聊聊什么是CPU上下文切换

对于linux来说&#xff0c;本身就是一个多任务运行的操作系统&#xff0c;运行远大于CPU核心数的程序&#xff0c;从用户视角来看是并发执行&#xff0c;而在CPU视角看其实是将不同的CPU时间片进行分割&#xff0c;每个程序执行一下&#xff0c;就切换到别的程序执行。那么这个…

Controller统一异常处理和yaml配置

目录 Controller统一异常处理 url解析 static下静态资源文件的访问 配置类 如何访问static下的资源文件 yaml基础语法 注解赋值 批量注入 单个注入 Controller统一异常处理 Controller统一异常处理ControllerAdvice&#xff1a;统一为Controller进行"增强" …

golang在goland编译时获取环境变量失效

在golang中&#xff0c; 我们通常使用os包来获取环境变量&#xff0c;如&#xff1a; os.Getenv() os.LookupEnv() 等。 但如果我们使用goland编译器&#xff0c;在编译是&#xff0c;这时操作环境变量&#xff0c;会发现os包读取到的环境变量值不变&#xff1a; 新增后&am…

ubuntu20.4 更新中科大软件源

打开软件源配置文件以编辑&#xff1a; sudo nano /etc/apt/sources.list在编辑器中&#xff0c;你会看到当前的软件源列表。将这些源更改为一个可用的源&#xff0c;例如使用中国科大源&#xff1a; deb http://mirrors.ustc.edu.cn/ubuntu/ jammy main restricted universe …

(Clock Domain Crossing)跨时钟域信号的处理 (自我总结)

CummingsSNUG2008Boston_CDC.pdf 参考&#xff1a; 跨时钟域处理方法总结–最终详尽版 - love小酒窝 - 博客园 跨时钟域&#xff08;CDC&#xff09;设计方法之单bit信号篇&#xff08;一&#xff09; | 电子创新网赛灵思社区 孤独的单刀_Verilog语法,FPGA设计与调试,FPGA接口与…

LVGL移植win端模拟显示流畅解决方案-使用 SquareLine 生成前端 UI 文件

lvgl_port_win_vscode 在 win 平台对 lvgl 方便的进行模拟显示&#xff0c;程序文件结构清晰&#xff0c;lvgl with SDL2&#xff0c;cmake 构建&#xff0c;VsCode 一键运行&#xff0c;使用 SquareLine 生成前端 UI 文件&#xff0c;win 上直接跑。 相比官方的 lvgl 移植到…

不同层设置不同学习率

使用预训练模型时&#xff0c;可能需要将 &#xff08;1&#xff09;预训练好的 backbone 的 参数学习率设置为较小值&#xff0c; &#xff08;2&#xff09;而backbone 之外的部分&#xff0c;需要使用较大的学习率。 from collections import OrderedDict import torch.nn …

Redis 集合(Set)快速指南 | Navicat

Redis 支持通过多种数据类型来存储项目集合。其中&#xff0c;包括列表、集合和哈希。上周的博文介绍了列表&#xff08;List&#xff09;数据类型并重点介绍了一些用于管理列表&#xff08;List&#xff09;的主要命令。在今天的文章中&#xff0c;我们将转向关注集合&#xf…

P-MVSNet ICCV-2019 学习笔记总结 译文 深度学习三维重建

文章目录 5 P-MVSNet ICCV-20195.0 主要特点5.1 文章概述5.2 研究方法5.2.1 特征提取5.2.2 学习局域匹配置信5.2.3 深度图预测5.2.4 Loss方程MVSNet系列最新顶刊 对比总结5 P-MVSNet ICCV-2019 深度学习三维重建 P-MVSNet-ICCV-2019(原文、译文、批注) 下载 5.0 主要特点 …

【MySQL基础】--- 约束

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【MySQL学习专栏】&#x1f388; 本专栏旨在分享学习MySQL的一点学习心得&#xff0c;欢迎大家在评论区讨论&#x1f48c; 目录 一、什么…

Ceph入门到精通-ceph pool 删除导致 misplaced 的原因

misplaced 的原因 Ceph中的misplaced对象是指将对象&#xff08;或对象的副本&#xff09;存储在错误的位置上&#xff0c;这可能会导致性能下降或数据不一致的问题。在删除Ceph池时&#xff0c;可能会导致misplaced的原因有以下几个&#xff1a; 删除过程中的操作失误&#x…

Python 打印文本进度条

""" 打印文本进度条知识点&#xff1a;1、字符串运算&#xff0c;注意只能适用于加法、乘法&#xff0c;例如&#xff1a;123 123 123123例如&#xff1a;123 * 3 1231231232、循环语句while、for3、条件语句if4、重点&#xff1a;转义字符\r&#xff0c;可以…

【springMvc】自定义注解的使用方式

&#x1f3ac; 艳艳耶✌️&#xff1a;个人主页 &#x1f525; 个人专栏 &#xff1a;《Spring与Mybatis集成整合》 ⛺️ 生活的理想&#xff0c;为了不断更新自己 ! 1.前言 1.1.什么是注解 Annontation是Java5开始引入的新特征&#xff0c;中文名称叫注解。 它提供了一种安全…

python的多线程多进程与多协程

python的多线程是假多线程&#xff0c;本质是交叉串行&#xff0c;并不是严格意义上的并行&#xff0c;或者可以这样说&#xff0c;不管怎么来python的多线程在同一时间有且只有一个线程在执行(举个例子&#xff0c;n个人抢一个座位&#xff0c;但是座位就这一个&#xff0c;不…

Unity中UI组件对Shader调色

文章目录 前言一、原理在Shader中直接暴露的Color属性&#xff0c;不会与UI的Image组件中的Color形成属性绑定。因为UI的Image组件中更改的颜色是顶点颜色&#xff0c;如果需要在修改组件中的颜色时&#xff0c;使Shader中的颜色也同时改变。那么就需要在应用程序阶段传入到顶点…

gin 基本使用

gin 初体验 import ("net/http""github.com/gin-gonic/gin" )func main() {r : gin.Default()r.GET("/ping", func(c *gin.Context) {c.JSON(http.StatusOK, gin.H{"message": "pong",})})r.Run() }gin 路由接受一个 type …

数据结构和算法(8):搜索树(二叉搜索树和AVL树)

查找 所谓的查找或搜索&#xff0c;指从一组数据对象中找出符合特定条件者&#xff0c;这是构建算法的一种基本而重要的操作。其中的数据对象&#xff0c;统一地表示和实现为 词条&#xff08;entry&#xff09; 的形式&#xff1b;不同词条之间&#xff0c;依照各自的 关键码…