7 Star 72 Fork 20

编程语言算法集 / EverydayWechat

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README
MIT

python_vesion itchat_vesion codebeat badge Codacy Badge MIT weibo GitHub issues GitHub contributors 微信群

EverydayWechat 是基于 Python3 与 Itchat 的微信小工具。
可以定时给朋友或者群聊发送每日天气、提醒、每日一句,也可以智能自动回复好友信息。还有群助手功能,让你在好友群中装 X。 操作简单,小白用户也可快速上手。

本项目依赖于网页版微信进行开发,如登录不了,则无法使用此项目;且无任何解决办法。
本项目依赖于网页版微信进行开发,如登录不了,则无法使用此项目;且无任何解决办法。
本项目依赖于网页版微信进行开发,如登录不了,则无法使用此项目;且无任何解决办法。
网页版微信地址:https://wx.qq.com/

在北京地区求一份 Python & Android 的工作岗位。
加微信:地址

版本更新日志

最近搞了一个类似,但功能不一样的项目:微信加群助手
欢迎大家 star。

禁止将本工具用于商业用途,如产生法律纠纷与本人无关。

注意:如果给女朋友添加图灵机器人回复,请慎重考虑!!!!
并不是你的每一个女朋友都能接受,你用机器人给他回复『暖心话』,安慰她。人工智能也有可能是一个智障机器人。想想如果机器人回复给你女朋友:『我们分手吧』。可能你们真的就分手了。虽然我会在心里默默的点个赞(单身狗的自白)

GitHub stars GitHub forks 请点击页面顶部靠右 star 与 fork

功能说明

  • 支持对多个微信好友自动回复。
  • 定时给好友与群聊组发送提醒,内容包括(天气、格言、自定义的话)。
  • 群助手功能,可以群自动回复,查询最热门的垃圾分类、天气、日历、实时票房、快递信息、PM2.5等等功能。

如果你没有好友可测试发送提醒,而且只有一个人也玩不了自动回复,怎么办呢(快哭了.jpg)。
你可以把『文件传输助手』当成女朋友添加(你说的这个女朋友到底是不是你的双手.jpg)。这样一个号也可以进行测试了,发提醒给文件传输助手,跟文件传输助手智能聊天。

相关数据来源

天气信息:

每日一句:

人工智能机器人

星座运势

万年历

票房数据:

垃圾分类查询:

空气质量PM2.5查询:

项目配置

目前项目所有的配置都是在 _config.yaml 文件中。
配置文件请严格遵循 yaml 语法格式,yaml 学习地址:
https://ansible-tran.readthedocs.io/en/latest/docs/YAMLSyntax.html
http://einverne.github.io/post/2015/08/yaml.html

配置自动回复机器人。

1. 开启自动回复

  • is_auto_relay 设置为:True。

2.选择渠道

机器人渠道(1: 图灵机器人,2: 一个AI ,3 : 青云客,4 腾讯智能闲聊,5:天行机器人,6:海知智能,7:思知机器人)
bot_channel: 7

默认为思知机器人,可不申请 key 的情况下,最智能的了。。

3. 指定自动回复的好友名单

有两种模式

(1) 不使用自动回复所有好友的情况下,即:is_auto_reply_all:False 时。
这时设置可回复的白名单成员,如下:

is_auto_reply_all:False
# 指定自动回复的好友名单。
auto_reply_white_list:
  - '好友1'
  - '好友2'

(2) 开启自动回复所有好友的情况下,即:is_auto_reply_all:True 时。
选择不自动回复黑名单成员:如下

is_auto_reply_all:True
auto_reply_black_list:
    - '好友1'
    - '好友2'

4. 配置相关器人

除了青云客之外,其他的机器人都需要去对应的官网,注册并获取相应的 key。需要哪个就配置哪个。

I.图灵机器人
  • 打开图灵机器人官网:http://www.turingapi.com 进行注册。
  • 创建机器人,得到 apikey。将填入到 _config.yaml 文件中的:

注意:不要打开『密钥』选项。

turing_conf:
  apiKey: '你所获取apikey'

图灵机器人必须认证后才能使用,免费版用户,每天可使用 100 条信息,且用且珍惜。

II.天行机器人
txapi_conf:
  app_key: '个人中心中的key'
  reply_name: '宝宝' # 回复的人的名字(可空)(也可在个人中心->机器人管理 修改)
  bot_name: '老公' # 机器人的名字(可空)
III.智能闲聊(腾讯)
  • 打开 https://ai.qq.com/product/nlpchat.shtml 并登录。
  • 点击免费使用 -> 接入能力 -> 创建应用 -> 创建成功后,会显示出 app_id ,app_key 。
  • 点击应用管理 -> 『你创建的项目名』-> 接入能力 -> 智能闲聊 -> 了解更多 -> 接入能力->『选择项目』-> 确认接口。
    将 app_id,app_key 填入 yaml 中。
qqnlpchat_conf:
    app_id: '你申请的api_id'
    app_key: '你申请的app_key'
IV.配置「一个AI」

打开图灵机器人官网:http://www.yige.ai 进行注册。
创建应用,得到「API密钥」中的 「客户端访问令牌」
将填入到 _config.yaml 文件中的:

yigeai_conf:
  client_token: '客户访问令牌'
V.配置「思知机器人」

打开思知官网:https://www.ownthink.com/ 进行注册。
创建机器人,得到 appid。
将填入到 _config.yaml 文件中的:

ownthink_conf:
    app_key: '你申请的api_id'

关于自动回复,目前可以公开的情报:

  1. 只能自动回复文字类消息;
  2. 如果消息发送太频繁,微信会限制登录网页端登录。放心,并不会封号;
  3. 好友里可以填入名称『文件传输助手』,这样你就可以在文件传输助手,发送消息,查看自动回复消息效果。

配置定时提醒

1.开启并设置提醒时间

  • is_alarm 设置成 True。(当为 False 时,则关闭定时)
alarm_info:
  is_alarm: True

2.填写需要发送的好友信息

填写好友信息,例如:

alarm_timed:
  - "9:00"
  - "12:30"
  - "22:00"
wechat_name:
  - '文件传输助手'
  - '诗风'
group_name:
  - 'EverydayWechat 交流群'
is_tomorrow: False
city_name: '桂林'
dictum_channel : 3
start_date: '2017-10-10'
start_date_msg: '爱你的第{}天'
calendar: True
horescope: "处女座"
sweet_words: '你脚下的蚂蚁'

相关参数说明:

名称 示例 必填 说明
wechat_name '老婆' 选填 好友名:可填多人。好友微信昵称或者备注名(不能输入微信号)
alarm_timed '9:30' 必填 定时时间,可填多个
alarm_jitter 300 可空 定时时间的前后300秒内随机发送
group_name '交流群' 选填 群聊名称,可填多个。必须要把需要的群聊保存到通讯录。
is_tomorrow True 可空 是否发送明日信息(如天气,星座,万年历)。
city_name '成都' 可空 城市名:朋友所在城市,用于发送天气。
air_quality_city '成都' 可空 空气质量 PM25 的城市。
dictum_channel 2 可空 格言渠道(见下表)
start_date '2017-10-10' 可空 相识日期:计算到当天的天数 。
start_date_msg '爱你的第{}天' 可空 相识日期文案
sweet_words '来自你俊美的老公' 可空 甜密的后缀。(钢铁直男的直描)
horescope '处女座' 可空 星座名或好友生日。用于发送星座运势
calendar True 可空 万年历信息

wechat_namegroup_name 至少要有一个。

格言渠道 : 1 : ONE●一个,2 : 词霸(每日双语),3: 土味情话, 4 : 一言,5:笑话,6: 民国情书,7: 彩虹屁。

Tips:可以把 wechat_name 填入『文件传输助手』,这样,提醒会发送到自己微信里的 文件传输助手 中。在不打扰别人的情况下,方便快速查看效果。

  • alarm_time 设置成需要提醒的时间。之后如果微信没有断线,即每天这个的时间会定时发送提醒。

如果需要快速体验,可将 alarm_timed 当前系统时间之后的几分钟。例如当前时间为 11:35,并设置 5 分钟后发送提醒,即:alarm_timed:11:40

当然,你也可以根据自己的需求,设置另一套不同的方案。具体参考代码。

一例提醒:

2019-06-29 星期六 农历五月廿七 
【宜】嫁娶,祭祀,沐浴,扫舍,修饰垣墙 
【忌】行丧,安葬 
桂林天气预报 
【今日天气】阵雨
【今日温度】低温 26.0℃,高温 33.0℃ 
【今日风速】南风<3级
【出行提示】阵雨来袭,出门记得带伞 
【桂林PM2.5】142 轻度污染
处女座今日运势 
【幸运颜色】2
【幸运数字】薄荷绿
【综合运势】今天的你有机会重逢旧同学、旧朋友,对方会为你带来一些小惊喜,可能是某个不错的商机,也可能是某个消息。工作/学习上,今天的你目标性很强,能把当初奋斗的初心捡回来,重新出发。感情方面,有伴者今天要提防烂桃花的挑拨离间,多给对方一些信任。
你知道五氧化二磷被氧化前是什么样子嘛,什么样子?五二磷。 
宝贝这是我们在一起的第628天 
你脚下的蚂蚁

配置群助手功能

直接放表格说明吧。

名称 示例 必填 说明
is_open True 必填 是否开启群助手功能
is_all True 必填 是否对所有群开启。当开启时,只有黑名单的名单才不受影响(慎重开启!)
group_name_white_list 「群名」 选填 白名单用户。当 is_all:Fase。只处理这个群里的消息
group_name_black_list 「群名」 选填 黑名单用户。当 is_all :True 。这个群里的用户不受影响。
is_at True 必填 艾特标记。只有当别人艾特自己时,才会处理消息(慎重关闭!)。
is_auto_reply True 必填 # 开启群自动回复(慎重开启!)
is_weather True 必填 是否开启天气查询。
is_calendar True 必填 是否开启万历年查询
is_rubbish True 必填 是否开启垃圾查询
is_moviebox True 必填 是否开启电脑票房查询
is_express True 必填 是否开启快递信息查询
is_air_quality True 必填 是否开启空气质量查询

配置数据库(可不配置)

首先得安装 mongodb 数据库安装。安装方式,请自行谷歌。
官方的安装教程也有:https://docs.mongodb.com/v3.2/administration/install-community/

(1)将 is_open_db 设置成 「True」。
(2)设置 host 与 port。tips: 没有特殊要求,或者对数据库不熟悉者不需要设置。

安装

首先,把 Python3 安装好,并配置好环境,个人建议新手安装 Anaconda,具体安装教程,可自行谷歌搜索~

直接下载此项目或 clone 项目到本地。

使用 pip 安装依赖:

pip3 install -r requirements.txt
# 或者是使用 pip
# pip install -r requirements.txt

运行

在本地 cmd 中跳转项目目录下,运行:

python run.py

第一次运行会跳出二维码,扫码登录。如输出日志中打印成:『登录成功』,则表示运行成功。
登录成功后一段时间内再运行,微信会保持登录状态,不需要再扫码。
如果需要切换用户,则在 _config.yaml 文件中,修改 is_forced_switch 的属性为 True。

  • docker 下运行
    • 构建 docker build -t everyday_wechat:v1 .
    • 运行 docker run everyday_wechat:v1

示例截图:

日志

自动回复

issues & 加群提问的建议。

  • 当你拋出一个技术问题时,最终是否能得到有用的回答,往往取决于你所提问和追问的方式。推荐阅读:提问的智慧
  • 检查是否是最新的代码,检查是否是 Python3.5+,检查依赖有没有安装完整
  • 先检查微信是否可登录 微信网页版,如网页端不能用,此项目也不能用。
  • 请更新你的 itchat 至最新版本 1.3.10 。查看 itchat 版本 print(itchat.version )
  • 与微信相关的问题可以先去 itchat issues, 查看是否有相似问题。
  • 微信名只能是昵称或者备注名,不能输入微信号。
  • 对群聊操作时,必须要把需要的群聊保存到通讯录。
  • 如果有新的思路和建议也欢迎提交。

Credits 致谢

本项目受以下项目启发,参考了其中一部分思路,向这些开发者表示感谢。

微信交流群

因为人数已超 100 人,请加 wx: sfyc1314 机器人为好友,验证信息写填写:「github」!!!,机器人会自动通过。
通过后回复:「加群」,会自动拉你入群。 加群助手也已开源,地址:https://github.com/sfyc23/WechatAddGroupHelper,欢迎大家 star。
机器人二维码:

微信交流群

捐助

如果您认为这个项目有帮助,不妨为它捐助一点钱?

不管钱有多少,您的捐助将会激励作者持续开发新功能!🎉

感谢您的支持!

捐助方法如下:

LICENSE

MIT License

MIT License Copyright (c) 2019 Thunder Bouble Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

简介

用 Python + itchat 写一个爬虫脚本每天定时给多个女友发给微信暖心话 展开 收起
Python 等 2 种语言
MIT
取消

发行版

暂无发行版

贡献者

全部

近期动态

加载更多
不能加载更多了
Python
1
https://gitee.com/TheAlgorithms/EverydayWechat.git
git@gitee.com:TheAlgorithms/EverydayWechat.git
TheAlgorithms
EverydayWechat
EverydayWechat
master

搜索帮助