码迷,mamicode.com
首页 > 微信 > 详细

微信小程序

时间:2019-06-03 15:49:06      阅读:228      评论:0      收藏:0      [点我收藏+]

标签:off   city   int   技术   一个   read   name   append   app   

 

所用库

1、pillow 2、pyecharts 3、itchat 4、jieba 5、numpy 6、pandas 7、wxpy

温馨提示:1、本篇博因需要所用pyecharts为0.5.X版本,anaconda所下载的是1.X.X版本

                  2、调用pyechart中的map模块需要安装地图数据包:

        pip install echarts-china-provinces-pypkg
        pip install echarts-countries-pypkg

一、登陆微信并获取我的好友相关信息

from wxpy import *
#初始化机器人,选择缓存模式(扫码)登录
bot=Bot(cache_path=True)
#获取我的所有微信好友信息
friend_all=bot.friends()
print(friend_all[0].raw)#friend_all[0]是我的微信昵称,.raw 则是获取我的全部信息
############运行后会自动弹出二维码页面,手机扫描登陆即可###########

运行结果

技术图片

二、可以查看我们的列表中联系人的数量

print(len(friend_all)
>>>179

三、获取好友相关信息,并把它存放在一个excel表格

将获取的好友信息所需要的部分进行处理,每个好友的信息都是一个字典,对这几个 key 提取相应的值,放入一个列表 list_0 中,即每个好友的这些 key的值做成了一个列表,在对所有的好友使用 for 循环进行同样的操作,将所有好友的列表做成一个大列表lis的元素,即列表中的元素是列表。

lis=[]
for a_friend in friend_all:
    NickName=a_friend.raw.get(NickName,None)
    #Sex=afriend.raw.get(‘Sex‘,None)
    Sex={1:"",2:"",0:"其他"}.get(a_friend.raw.get(Sex,None),None)
    City=a_friend.raw.get(City,None)
    Province=a_friend.raw.get("Province",None)
    Sigenature=a_friend.raw.get("Signature",None)
    HeadImgFlagUrl=a_friend.raw.get("HeadImgFlagUrl",None)
    HeadImgFlag=a_friend.raw.get("HeadImgFlag",None)
    list_0=[NickName,Sex,City,Province,Sigenature,HeadImgFlagUrl,HeadImgFlag]
    lis.append(list_0)

然后再将列表放入创建的excel表格中

def lis2e07(filename,lis):
    import openpyxl
    wb = openpyxl.Workbook()
    sheet = wb.active
    sheet.title = list2excel07
    file_name = filename +.xlsx
    for i in range(0, len(lis)):
        for j in range(0, len(lis[i])):
                sheet.cell(row=i+1, column=j+1, value=str(lis[i][j]))
    wb.save(file_name)
    print("写入数据成功!")
lis2e07(‘list3‘,lis)

结果显示

技术图片

四、统计列表联系人所在城市占比

#######################粗略获取好友信息###############################
Friends=bot.friends() data=Friends.stats_text(total=True,sex=True,top_provinces=30,top_cities=300) print(data)
######可以从存储在本地的 excel 中读取数据进行分析在执行以
下代码之前,我们需要先把 excel 文件加一个列标题行。可直接另存为上面的excel表格
然后增加后续直接用另存为的表格########################
from pandas import read_excel df=read_excel(list4.xlsx,sheet_name=list2excel07) print(df.tail(7)) df.city.count() df.city.describe()

结果显示

技术图片技术图片

 

五、对列表中联系人所在城市绘制词云

①利用PIL+WordCloud对列表联系人所在城市绘制词云

from wordcloud import WordCloud
import matplotlib.pyplot as plt
import pandas as pd
from pandas import DataFrame
word_list= df[city].fillna(0).tolist()#将 dataframe 的列转化为 list,其中的 nan 用“0”替换
new_text =  .join(word_list)
wordcloud = WordCloud(font_path=simhei.ttf, background_color="black").generate(new_text)
plt.imshow(wordcloud)
plt.axis("off")
plt.show() 

结果显示

技术图片

②用pyecharts绘制词云并将其保存为html文件

import pandas as pd
#count=df.city.value_count()#对dataframe对 dataframe 进行全频率统计,排除了 nan
city_list=df[city].fillna(NAN).tolist()#将dataframe的列转化为list,其中nan用NAN替换
count_city=pd.value_counts(city_list)#对list进行全频率统计
from pyecharts import WordCloud
name=count_city.index.tolist()
value=count_city.tolist()
wordcloud=WordCloud(width=1300,height=620)
wordcloud.add("",name,value,word_size_range=[20,100])
wordcloud.show_config()
wordcloud.render(rcy.html)

结果显示

技术图片

六、列表联系人所在省份地图并保存为HTML文件

province_list=df[province].fillna(NAN).tolist()
count_province=pd.value_counts(province_list)#对list进行全频率统计
from pyecharts import Map
value=count_province.tolist()
attr=count_province.index.tolist()
map=Map("各省微信好友分布",width=1000,height=600) 
map.add("",attr,value,maptype=china,is_visualmap=True,visual_text_color=#000,is_label_show=True)#显示地图上的省份
map.show_config()
map.render(rFriendMap.html)

注:若地图显示不全或者只显示南海诸岛部分请安装map数据包(安装方法见本博开头)

显示结果

技术图片

 

 

 OK,也同样可以查看各市的好友分布,就不贴图了,有兴趣可以试试。

微信小程序

标签:off   city   int   技术   一个   read   name   append   app   

原文地址:https://www.cnblogs.com/SGzhang/p/10964705.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!