itchat怎么一直登录(无法用itchat登录网页微信)
大家好!今天让创意岭的小编来大家介绍下关于itchat怎么一直登录的问题,以下是小编对此问题的归纳整理,让我们一起来看看吧。
ChatGPT国内免费在线使用,能给你生成想要的原创文章、方案、文案、工作计划、工作报告、论文、代码、作文、做题和对话答疑等等
你只需要给出你的关键词,它就能返回你想要的内容,越精准,写出的就越详细,有微信小程序端、在线网页版、PC客户端,官网:https://ai.de1919.com
本文目录:
一、用python怎么设计一个微信的接口
最近一段时间想看看能不能用万能的python来对微信进行一些操作(比如自动抢红包之类的...hahahaha),所以就在此记录一下啦~~
1、安装
sudo pip install itchat
2、登录
itchat.auto_login()
注:itchat.auto_login()这种方法将会通过微信扫描二维码登录,但是这种登录的方式确实短时间的登录,并不会保留登录的状态,也就是下次登录时还是需要扫描二维码,如果加上hotReload==True,那么就会保留登录的状态,至少在后面的几次登录过程中不会再次扫描二维码,该参数生成一个静态文件itchat.pkl用于存储登录状态
itchat.auto_login(hotReload=True)
3、退出登录
主要使用的是回调函数的方法,登录完成后的方法需要赋值在 loginCallback中退出后的方法,需要赋值在 exitCallback中.若不设置 loginCallback的值, 将会自动删除二维码图片并清空命令行显示.
import itchat,time
def lcb():
print("登录完成!")
def ecb():
print("退出成功!")
itchat.auto_login(loginCallback=lcb,exitCallback=ecb) #源码中规定需要用回调函数。
time.sleep(10)
itchat.logout() #强制退出登录
4、发送消息
send()
itchat.send(msg="WANGPC的微信消息!",toUserName="filehelper") #返回值为True或Flase
实例:
或者:
send_msg
send_msg(msg='Text Message', toUserName=None),其中的的msg是要发送的文本,toUserName是发送对象, 如果留空, 将发送给自己,返回值为True或者False
实例代码
send_file
send_file(fileDir, toUserName=None) fileDir是文件路径, 当文件不存在时, 将打印无此文件的提醒,返回值为True或者False
实例代码
send_image
send_image(fileDir, toUserName=None) 参数同上
实例代码
send_video
send_video(fileDir, toUserName=None) 参数同上
实例代码
二、微信加长代码撤回消息
自从微信出了这个消息撤回功能小编我都已经快被折磨死了,小编本来就是个好奇心比较重的人,微信出了这个功能之后小编感觉身体一天不如一天了,每次看着女神发来的信息又撤回,可谓是心里痒痒啊。所以小编就写了一个微信消息撤回捕捉器,下面就让小编教你怎么摆脱单身逆袭白富美。
1,模块介绍
首先的话要实现消息撤回捕捉得用到python上一个十分强大的库:itchat。如果大家没有使用过的话小编就来介绍一下:
Project description
itchat is a open souce wechat api project for personal account.
It enables you to access your personal wechat account through command line.
以上意思就是:itchat是一个面向个人账户的开源微信api项目。您可以通过命令行访问您的个人微信帐户。 所以说我们今天就要用到这个库,首先我们要 :
pip install itchat
2,模块功能熟悉
小编这里考虑到有些小伙伴从来没用过这个模块,所以下面会对这个模块进行一个简单的讲解。
2.1 如何登录微信
既然我们要捕捉微信的撤回信息那第一步肯定是要先登录微信,登录微信非常简单只需要两行代码:
import itchat?itchat.login()
这样就好了,是不是特别简单,然后运行之后就会出现一个二维码,扫描之后再手机上面授权登录,控制台就会显示你是否登录成功。
·Login successfully as .
这样就说明你登录成功了,但是这边如果是新创建的微信和长期不使用的微信的话是无法登录网页版微信的,所以这里也会导致登录不上。如果登录不上,那也是没有办法的
2.2 获取好友列表
import itchat
itchat.auto_login(hotReload=True)
friends = itchat.get_friends() # 好友列表
print(friends)
使用get_friends()这个函数就能获取到好友列表的所有好友信息,包括昵称,备注名,地址,个性标签,性别等等。
[{'UserName':
'@7c2215e17edf4b193f125d6ecf944abcaf19ba72e3eb24b8442d5e32d4a8be92',
'City': '', 'DisplayName': '', 'PYQuanPin': '', 'RemarkPYInitial':
'', 'Province': '', 'KeyWord': '', 'RemarkName': '', 'PYInitial': '',
'EncryChatRoomId': '', '**': '', 'Signature': '', 'NickName': '**',
'RemarkPYQuanPin': '', 'HeadImgUrl': '**'
这里我就随便复制了一个好友的信息,关于到隐私的问题我就把信息全部用**代替了,我们重点是分析一下这些信息的内容,比如最开始的UserName这个是用户的唯一标识,相当于身份证号码一样的,所有的好友UserName都是不一样的,然后是NickName:这是好友的昵称,HeadImgUrl:这是好友的头像地址,还有一些就不一一介绍了,大家感兴趣的话可以自己去了解一下
2.3 发送信息给好友
我们现在准备发送一条信息给好友,具体怎么操作呢?看下面代码:
import itchat
itchat.auto_login(hotReload=True)
itchat.send("人生苦短,我学python",toUserName="@c4326bda513bf7cdd19f1fa03dbf7e7bc3bbc57e5abb71fd580b2c3c32cddd99")
itchat.send()这个函数可以放两个参数,第一个你要发送给好友的信息,第二个指定好友也就是toUserName=上面所说的唯一身份标识UserName但是上面方法我觉得还是有点不妥,然后我就改进了一下:
import itchat
itchat.auto_login(hotReload=True)friends = itchat.get_friends()nickName = '你秃我不秃'
for i in friends:
if '你秃我不秃' == i['NickName']:
itchat.send('人生苦短,我学python', toUserName=i['UserName'])
break
这样我就可以发信息给任意好友,通过好友的昵称哎好友列表中进行查找,找到的话我就获取该好友的UserName然后发送消息,也可以通过对好友的备注名RemarkName查找,大家可以根据自己的喜好选择
2.4 装饰器
关于itchat这个模块还有很多功能,小编在这里就不做过多讲解了,我们只要了解消息撤回所需要的知识点就行了,然后我们进行最后一个内容,装饰器 关于装饰器小编这边简单介绍一下,装饰器的是勇于扩展原来函数功能的一种函数,目的是再不改变原函数名的情况下给函数增加新的功能。 例如我喜安智又一个函数foo(),你并不知道函数的实现原理,你肯定也不能去修改这个函数的代码而你需要给这个函数添加一个输出开始运行时间和结束运行时间的功能,改如何实现,这时候你就可以用装饰器了:
import time
def show_time(foo):
def inner():
print(time.time()) foo() print(time.time()) return inner
@show_timedef foo(): passfoo()
上面这段代码的意思:首先@show_time就是使用一个装饰器show_time,这个时候就会将装饰器的函数,也就是foo()作为参数传递给装饰器show_time(),我们知到函数作为返回值的话,执行的其实是该函数,所以程序会执行内部函数inner(),此时输出开始运行时间,然后调用foo()函数,最后输出结束运行时间,这样就实现了一个功能扩展,这也是很典型的面向切面编程思想。
3,如何监听好友撤回的信息
其实到了这里我们就已经完成了消息的监听只需要稍加修改就好了,但是这个程序还是有一点问题的,就是所有的消息我们都需要去保存,好友正常发送过来的消息我们直接就能看到保存下来不是多此一举吗,我们的目的是想知道好友撤回了什么内容,这里就涉及到如何监听好友是否撤回了信息这个问题了,其实也不难,Content模块为我们提供了NOTE类型,这个类型指的是系统消息,所以我们可以自定义一个函数用来监听系统消息:
import itchat
from itchat.content import * # 导入itchat下的content模块
itchat.auto_login(hotReload=True)
@itchat.msg_register(NOTE)
def note_info(msg): # 监听系统消息
print(msg)
itchat.run()
运行程序,我们撤回一条信息测试一下,输出的结果如下:
'DisplayName': '', 'ChatRoomId': 0, 'KeyWord': '', 'EncryChatRoomId': '', 'IsOwner': 0}>, 'Type': 'Note', 'Text': '你撤回了一条消息'}
则例截取的部分的内容这样会发小撤回信息的文本内容“你撤回了一条信息”,如意要想知道好友是否撤回了消息就很简单了,判断一下,msg['Text']=='你撤回了一条信息'就行了
4, 实现微信消息撤回捕捉功能
现在关于程序的每个步骤代码到这里也就分析完了,接下来就是对所有的代码进行一个总结以下就是所有代码的总结:
现在我们来测试一下首先我让我两个朋友一人给我发了一条信息:
三、Python需求:什么值得买登录、签到、搜索功能
最近想买个行车记录仪,经常在在什么值得买上搜索信息,感觉浪费的时间比较多,就想用Python写个自动搜索的功能。另外,什么值得买已经很久没有签到了,刚开始玩的时候台天天签到,乐此不疲。现在已经很久没有签到了,既然我是码农,当然得实现自动化哈。
1.实现自动登录;
2.实现自动签到;
3.实现搜索功能;
requests库应该就能实现这些功能,但是需要解析页面,我这些需求简单,没有性能要求,因此采用简单的selenium库模拟浏览器操作实现这个需求。
selenium、BeautifulSoup
关于selenium的使用在 Python爬取煎蛋妹子图 里有介绍。
遇到的坑:
1.点击登录按钮后,弹出登录框,后续无法找到用户名、密码的element。
开始以为是点击登录后,马上就去获取这个element,此时登录框还没有弹出来,因此延迟了3秒(这个问题在模拟登录百度时碰到过)。依旧不能解决。问题原因就是没有获取到当前登录框的handle,因此获取所有的window_handle,然后切换到当前的,debug发现是始终只有一个handle。
其实什么值得买的登录框是一个frame,需要采用switch_to.frame方法定位到当前frame。
搜索只处理了搜索结果的第一页,如果需要更多的数据,处理分页即可。
以上三个方法即实现了三个功能需求,但是我想要每天自动实现登录、签到功能,同时搜索‘行车记录仪’处理结果能够发送到手机。实现搜索结果发送到手机,自然想到了 itchat 这个库。另外使用 apscheduler 实现了定时任务。
下面开始列遇到的坑:
1.签到时
写的时候没注意,捕获异常写了EOFrror,导致签到过后,后续不会发送微信消息。EOFrror是意味着它发现了一个不期望的文件尾时会抛出的异常,因此这里不会捕获到。
修改成:
四、基于wechaty的定时消息推送(可以哄女朋友)、智能聊天和私人助理
---
title: "基于wechaty的定时消息推送(可以哄女朋友)、智能聊天和私人助理"
author: jasonlovesharon
email: 54027901@163.com
tags:
- nodejs
- wechaty
- wechaty-puppet-padplus
---
## 前言
- 自从2017年微信web端API限制以后,itchat等一大批bot歇菜了,一直都在找一款合适的替品
- 目前来看,大部分都是针对windows微信客户端,基于HOOK的dll注入实现对微信的操控,有一定的封号风险,只能用固定的版本,部署在linux服务器端比较困难,意味着只能一直开着电- -wechaty,支持IPAD,,MAC等多种协议,不用去调用WEB网页API,并且可以布署在服务器,满足我所有需求。[项目地址](https://github.com/wechaty/wechaty)
- 看完官方文档后([token官方介绍](https://github.com/juzibot/welcome/wiki/everything-about-wechaty)), 发现需要申请Token,并且python版本的Token是要付费的,但没有学过typescript,有点想放弃,浏览了一下ding-dong-bot的Example,似乎可以看懂,那就边学习边摸索吧。(ps:后来偶然见发现了另一篇可以使用将token转变一下实现python版wechaty,但此时已经基本用TS写完了,如果想用Python等其他语言可以参考[官方文档](https://github.com/wechaty/wechaty/issues/1985)。)
## 具备功能
### 1. 关键词触发功能
1.1 关键词"介绍一下自己"、 "自我介绍一下"、 "你是谁"触发自我介绍
1.2 地名+天气 触发天气查询
### 2. 智能聊天功能
2.1群外直接聊天
2.2群内成员皆有聊天权限“@bot” 聊天
2.3不会回复 @其他群成员 的消息
## 实现过程
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'
// 创建微信每日说定时任务
async function initDay() {
console.log(`已经设定每日说任务`);
setSchedule('0 40 0 * * *', async () => {
console.log('你的贴心小助理开始工作啦!')
let logMsg
let contact =
(await bot.Contact.find({ name: 'Jason' })) ||
(await bot.Contact.find({ alias: 'boss' })) // 获取你要发送的联系人
let one = await getOne() //获取每日一句
let weather = await getTXweather() //获取天气信息
let today = await formatDate(new Date()) //获取今天的日期
let memorialDay = getDay('2009/08/07') //获取纪念日天数
let sweetWord = await getSweetWord()
let str = `${today}\n我们相爱的第${memorialDay}天\n\n元气满满的一天开始啦,要开心噢^_^\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) // 发送消息
} 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 = '你自己的机器人TOKEN' //需要在微信对话开放平台申请,点击机器人设置》绑定应用》在页面最下方即可看到
const openAIEncodingAESKey = '你自己的EncodingAESKey' //微信对话开放平台申请,点击机器人设置》绑定应用》在页面最下方即可看到
const preAnswerHook = async (message: Message) => {
const isCommonMaterial = await processCommonMaterial(message)
if (isCommonMaterial) {
return false
}
}
/**
* 获得boss联系名片,当机器人找不到问题答案时,将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('你的问题我不会回答,你可以联系我的老板')
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},你的问题我不会回答,你可以联系我的老板`
await room.say(boss)
}
}
/**
* 用wechaty-weixin-openai可以实现快速接入微信对话平台
*/
bot.use(WechatyWeixinOpenAI({
token: openAIToken,
encodingAESKey: openAIEncodingAESKey,
noAnswerHook, //在机器人无法回答时,推送设定的回答
preAnswerHook, //判断是否是关键字,如果是关键字,触发关键字回答而不接入微信开放平台
}))
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,爱好广泛,广交天下豪杰,上得了九天摘月,下得了五洋捉鳖,俗话说的好,不会烘培的飞行员不是好户外人,不会玩音乐的水族爱好者不是好厨师,不会画画的极限爱好者不是好程序员,这就是我的老板Jason,吼吼吼~~'
if (room !== null && mentionSelf) {
if (/jason|你老板|你上司/.test(text)) {
await room.say(intro)
await room.say(new UrlLink({
description: '户外贱客 & Fighting,fighting,finghting and finghting,读万卷书,行万里路,学习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,读万卷书,行万里路,学习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}登录了`)
// 登陆后创建定时任务
await initDay()
}
bot.on('login', onLogin)
bot.start()
.then(() => log.info('StarterBot', 'Starter Bot Started.'))
.catch(e => log.error('StarterBot', e))
```
### 2.创建schedule定时函数
```typescript
import { schedule } from 'node-schedule'
// date 参数
//其他规则见 https://www.npmjs.com/package/node-schedule
// 规则参数讲解 *代表通配符
//
// * * * * * *
// ┬ ┬ ┬ ┬ ┬ ┬
// │ │ │ │ │ |
// │ │ │ │ │ └ 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秒触发: '30 * * * * *'
//
// 每小时的1分30秒触发 :'30 1 * * * *'
//
// 每天的凌晨1点1分30秒触发 :'30 1 1 * * *'
//
// 每月的1日1点1分30秒触发 :'30 1 1 1 * *'
//
// 每周1的1点1分30秒触发 :'30 1 1 * * 1'
function setSchedule(date,callback) {
schedule.scheduleJob(date, callback)
}
export function setSchedule()
```
### 3.创建几个功能函数,爬取ONE网站的每日一句,提取通过API获取的消息
```typescript
import * as cheerio from 'cheerio'
import * as superagent from 'superagent'
const ONE = 'http://wufazhuce.com/' // ONE的web版网站
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('错误', 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}风: ${todayInfo.windspeed}\n紫外线指数:${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, }
```
### 计算距离某日(生日,结婚纪念日等)还有多少天
```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 }
```




## 后记
到此已经实现了私人人助理和定时推送消息的功能([项目地址](https://github.com/jasonlovesharon/my_bot)),由于对Typescript不熟,很多功能都是借鉴很多大神的轮子实现的,还是对Python熟悉点,下步准备用Python来实现以上功能,并进一步拓展更多有趣的功能。
以上就是关于itchat怎么一直登录相关问题的回答。希望能帮到你,如有更多相关问题,您也可以联系我们的客服进行咨询,客服也会为您讲解更多精彩的知识和内容。
推荐阅读: