闲来无事,突然有个想法,来实现一个自己的qq机器人用来玩。使用的语言是刚学没多久的python。既然有了这个想法,我就开始了我的面向百度编程。
利用pyautogui实现
首先想到的就是利用windows窗口来实现内容的传送。这里就是使用到了python的第三方库pyautogui,窗口模拟点击那样子。有点蠢了。
import json
import time
import pyautogui
import pygetwindow as pw
import requests as requests
import pyperclip
name=input("请输入你的qq窗口名:")
window = pw.getWindowsWithTitle(name)[0]
window.show()
window.activate()
time.sleep(1) # 等待1秒
if window.isActive:
for i in range(0, 5):
res = requests.get('https://v1.hitokoto.cn/')
load = json.loads(res.text)
content = load['hitokoto']
pyperclip.copy(content)
pyautogui.click(500, 530, button='left') # 鼠标点击指定的位置
pyautogui.hotkey("Ctrl",'V')
pyautogui.press('enter') # 按键盘上的键
pyautogui.press('enter') # 按键盘上的键
显然上面这种方法有点蠢蛋。真正的机器人肯定不能这样。
go-cqhttp
然后我就发现了这个框架,是用golang写的。首先先去人家的github上下载一下。
运行那个bat批处理。启动go-cqhttp。
当我们选择了通信方式后,他会为我们自动生成配置文件。在yml里面的server配置就是我们所选择的通信方式后生成的,这里有四个通信方式,0就是我们基本的request和response。那websocket是什么呢?
websocket
websocket是一种实时通信方式,为了解决多次访问服务器的资源消耗,传统的http请求必须是请求才来访问,而websocket说做到的是服务器端可以主动向客户端发送响应。
在配置好http通信之后,我们就可以来尝试一下接收信息了。利用flask接收post,获取json数据后,将你想要的内容返回就好了。
import requests
from flask import Flask, request, json, url_for
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
from message.model import Message
app = Flask(__name__)
# 声明selenium自动化
options = Options()
options.add_argument("--headless")
driver = webdriver.Chrome(options=options)
@app.route("/", methods=['get', 'post'])
def robot_center():
robot_dict = request.get_json()
if robot_dict.get("message_type") == "group" and "[CQ:at,qq=2139253505]" in robot_dict["raw_message"]:
#放入message对象
message = Message(robot_dict.get('message_type'), robot_dict.get('group_id'), robot_dict.get('time'),
robot_dict.get('user_id'),
robot_dict.get('message_id'), robot_dict.get('target_id'))
# 获取这个信息
res = requests.get('http://127.0.0.1:5700/get_msg?message_id={}'.format(message.message_id))
res_dict = json.loads(res.text)
res_dict = res_dict.get('data')
message = res_dict["message"].replace("[CQ:at,qq=2786631176]", "") # 获取发送过来的消息
message__split = message.split()
if message__split[0] == '天气':
get_weather(message__split[-1], message)
elif message__split[0]=='':
data = {
'message_type': 'private',
'user_id': message.user_id,
'message': '我草你妈,@不说话是吧',
}
requests.post('http://127.0.0.1:5700/send_msg', data=data)
return "123"
def get_weather(location, message):
# driver.get('https://wttr.in/'+location)
# driver.get_screenshot_as_file('123.png')
global data
res = requests.get('https://wttr.in/' + location, params={'format': 4})
if message.message_type == 'private':
data = {
'message_type': 'private',
'user_id': message.user_id,
'message': res.text,
'auto_escape': True
}
elif message.message_type == 'group':
data = {
'message_type': 'group',
'group_id': message.group_id,
'message': res.text,
'auto_escape': True
}
print(data)
message_id = requests.post('http://127.0.0.1:5700/send_msg', data=data)
return message_id
if __name__ == '__main__':
app.config['DEBUG'] = True
app.run(host='127.0.0.1', port=8082)
这时候就可以根据天气 <任意地址>来获取天气啦。