Le code est placé ici : wzyonggege/python-wechat-itchat
Le nuage de mots peut être remplacé par une image de serviteur
--- - ------------------------------------------------- - ------------------------------------------------
Récemment, j'ai étudié quelques façons de jouer à WeChat. Nous pouvons utiliser la version Web de WeChat pour nous connecter en scannant le code QR pour capturer des paquets et explorer des informations, et nous pouvons. poster également pour envoyer des informations.
Puis j'ai découvert itchat, un projet open source L'auteur est @LittleCoder Il a complété l'interface WeChat, ce qui facilite grandement notre exploration de WeChat. discuter.
Installez la bibliothèque itchat
pip install itchat
Faisons d'abord un essai simple pour nous connecter à WeChat. L'exécution du code suivant générera un code QR après avoir scanné le. code Après avoir confirmé la connexion sur le téléphone mobile, un message sera envoyé à 'filehelper'. Ce filehelper est l'assistant de transfert de fichiers sur WeChat.
import itchat# 登录itchat.login()# 发送消息itchat.send(u'你好', 'filehelper')
En plus de se connecter et d'envoyer des messages, on peut aussi jouer comme ça, descendre ~
Think Il est bien sûr très simple de compter le ratio hommes-femmes de vos amis dans WeChat. Tout d'abord, obtenez la liste d'amis et comptez le nombre de sexes dans la liste
import itchat# 先登录itchat.login()# 获取好友列表friends = itchat.get_friends(update=True)[0:]# 初始化计数器,有男有女,当然,有些人是不填的male = female = other = 0# 遍历这个列表,列表里第一位是自己,所以从"自己"之后开始计算# 1表示男性,2女性for i in friends[1:]:sex = i["Sex"]if sex == 1:male += 1elif sex == 2:female += 1else:other += 1# 总数算上,好计算比例啊~total = len(friends[1:])# 好了,打印结果print u"男性好友:%.2f%%" % (float(male) / total * 100)print u"女性好友:%.2f%%" % (float(female) / total * 100)print u"其他:%.2f%%" % (float(other) / total * 100)
Installez-le d'abord
pip install echarts-python
# 使用echarts,加上这段from echarts import Echart, Legend, Piechart = Echart(u'%s的微信好友性别比例' % (friends[0]['NickName']), 'from WeChat')chart.use(Pie('WeChat', [{'value': male, 'name': u'男性 %.2f%%' % (float(male) / total * 100)}, {'value': female, 'name': u'女性 %.2f%%' % (float(female) / total * 100)}, {'value': other, 'name': u'其他 %.2f%%' % (float(other) / total * 100)}], radius=["50%", "70%"]))chart.use(Legend(["male", "female", "other"]))del chart.json["xAxis"]del chart.json["yAxis"]chart.plot()
# coding:utf-8import itchat# 先登录itchat.login()# 获取好友列表friends = itchat.get_friends(update=True)[0:]for i in friends:# 获取个性签名signature = i["Signature"]print signature
Après l'impression, vous constaterez qu'il y a beaucoup de champs span, class, emoji, emoji1f3c3, etc., car les émoticônes sont utilisées dans les symboles de signature personnalisés, ces champs doivent être filtrés. Écrivez une méthode régulière et remplacez pour filtrer
for i in friends:# 获取个性签名signature = i["Signature"].strip().replace("span", "").replace("class", "").replace("emoji", "")# 正则匹配过滤掉emoji表情,例如emoji1f3c3等rep = re.compile("1f\d.+")signature = rep.sub("", signature)print signature
pip install jieba pip install wordcloud
# coding:utf-8import itchatimport reitchat.login()friends = itchat.get_friends(update=True)[0:]tList = []for i in friends:signature = i["Signature"].replace(" ", "").replace("span", "").replace("class", "").replace("emoji", "")rep = re.compile("1f\d.+")signature = rep.sub("", signature)tList.append(signature)# 拼接字符串text = "".join(tList)# jieba分词import jiebawordlist_jieba = jieba.cut(text, cut_all=True)wl_space_split = " ".join(wordlist_jieba)# wordcloud词云import matplotlib.pyplot as pltfrom wordcloud import WordCloudimport PIL.Image as Image# 这里要选择字体存放路径,这里是Mac的,win的字体在windows/Fonts中my_wordcloud = WordCloud(background_color="white", max_words=2000, max_font_size=40, random_state=42, font_path='/Users/sebastian/Library/Fonts/Arial Unicode.ttf').generate(wl_space_split)plt.imshow(my_wordcloud)plt.axis("off")plt.show()
.
cela. . Cela semble un peu moche. Selon l'utilisation de Wordcloud, je peux trouver une image pour générer un jeu de couleurs ici
et j'ai modifié le code.
# wordcloud词云import matplotlib.pyplot as pltfrom wordcloud import WordCloud, ImageColorGeneratorimport osimport numpy as npimport PIL.Image as Imaged = os.path.dirname(__file__)alice_coloring = np.array(Image.open(os.path.join(d, "wechat.jpg")))my_wordcloud = WordCloud(background_color="white", max_words=2000, mask=alice_coloring, max_font_size=40, random_state=42, font_path='/Users/sebastian/Library/Fonts/Arial Unicode.ttf')\.generate(wl_space_split)image_colors = ImageColorGenerator(alice_coloring)plt.imshow(my_wordcloud.recolor(color_func=image_colors))plt.imshow(my_wordcloud)plt.axis("off")plt.show()# 保存图片 并发送到手机my_wordcloud.to_file(os.path.join(d, "wechat_cloud.png"))itchat.send_image("wechat_cloud.png", 'filehelper')
3. Réponse automatique WeChat
Le code est très simple, jetons un coup d'oeil
#coding=utf8import itchat# 自动回复# 封装好的装饰器,当接收到的消息是Text,即文字消息@itchat.msg_register('Text')def text_reply(msg):# 当消息不是由自己发出的时候if not msg['FromUserName'] == myUserName:# 发送一条提示给文件助手itchat.send_msg(u"[%s]收到好友@%s 的信息:%s\n" %(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(msg['CreateTime'])), msg['User']['NickName'], msg['Text']), 'filehelper')# 回复给好友return u'[自动回复]您好,我现在有事不在,一会再和您联系。\n已经收到您的的信息:%s\n' % (msg['Text'])if __name__ == '__main__':itchat.auto_login()# 获取自己的UserNamemyUserName = itchat.get_friends(update=True)[0]["UserName"]itchat.run()
Bien entendu, en plus des SMS, vous pouvez également recevoir des images (les émoticônes comptent comme des images), de la voix, des cartes de visite, de la localisation géographique, du partage et des informations de type Remarque (c'est-à-dire les messages demandés par quelqu'un, comme le retrait de messages) , il est acceptable d'écrire au décorateur sous la forme suivante, vous pouvez essayer
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!