加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

几十行代码让你知道伴侣圈都是什么样的伴侣

发布时间:2018-10-19 05:49:20 所属栏目:教程 来源:千锋大数据开发学院
导读:合几大常用的Python数据说明包,团结itchat的手段实现伴侣圈的说明。 从那边做起 微信此刻越来越融入到了我们每小我私人的糊口,从简朴的谈天器材到衣食住行的处事,再到撒播着富厚多彩信息的自媒体和涵盖万物的小措施,微信俨然就是一个小的生态体系。而人,
副问题[/!--empirenews.page--]

合几大常用的Python数据说明包,团结itchat的手段实现伴侣圈的说明。

从那边做起

微信此刻越来越融入到了我们每小我私人的糊口,从简朴的谈天器材到衣食住行的处事,再到撒播着富厚多彩信息的自媒体和涵盖万物的小措施,微信俨然就是一个小的生态体系。而人,是整个微信生态的焦点,每小我私纪忾侣圈就是自我小生态的焦点。itchat为我们提供了获取伴侣信息的接口:

  1. friends=itchat.get_friends(update=True)[0:] 

通过debug可以看到每个friend的信息:

几十行代码让你知道伴侣圈都是什么样的伴侣

可以看到每个挚友的信息照旧很富厚的,从昵称、性别、到区域等,挚友列表凭证通信录分列,第一个是用户本身,接着是星标置顶的挚友,好比瑾瑾在我的列内外排第一位。我们本日全部的事变都将从挚友的信息做起。

统计挚友性别漫衍

性别漫衍是最轻易统计的数据,通过查察我本身和几个挚友的数据,得出sex和性此外对应相关为:

  1. sex = 0: 未知sex = 1: 男生sex = 2: 女生  
  2. pyecharts 是一个用于天生 Echarts 图表的类库,而Echarts 是百度开源的一个数据可视化 JS 库。首要用于数据可视化。操作pyecharts画出挚友性别漫衍: 
  3. from pyecharts import Pie  
  4. boy=girl=nothing=0  
  5. for i in friends[1:]:  
  6. sex =i[Sex]  
  7. if sex==1:  
  8. boy+=1  
  9. elif sex==2:  
  10. girl+=1  
  11. else:  
  12. nothing+=1  
  13. total=len(friends[1:])  
  14. attr=[迷妹,迷弟 , 低调的匿名粉丝]  
  15. v1 = [boy,girl, nothing]  
  16. pie = Pie(粉丝性别漫衍, title_pos='center')  
  17. pie.add(, attr, v1, radius=[40, 75], label_text_color=None,is_label_show=True,is_legend_show=False)  
  18. pie.show_config()pie.render(./sex_data.html) 

运行功效如下:

几十行代码让你知道伴侣圈都是什么样的伴侣

没想到我的微信上的迷妹竟然比迷弟都多了这么多,其实是吃鲸,还但愿瑾瑾不要打我。

挚友区域漫衍

说明完挚友的性别我们再来说明挚友的区域漫衍,看看本身的挚友是不是遍布不着边际:

  1. from pyecharts import Map  
  2. import pandas as pd  
  3. def get_var(var):  
  4. variable=[]  
  5. for i in friends:  
  6. value=i[var]  
  7. variable.append(value)  
  8. return  
  9. variableNickName=get_var(NickName)  
  10. Sex=get_var(Sex)  
  11. Province=get_var('Province')  
  12. Signature=get_var('Signature')  
  13. city=get_var('City')  
  14. data{'NickName':NickName,'Sex':Sex,'Province':Province,'Signature':Signature,'city':city}  
  15. frame=pd.DataFrame(data)  
  16. result1=frame.groupby(['Province'],as_index=False).size()a1=list(result1)  
  17. a2=result1.indexmap=Map(我的挚友占了泰半此中国啊!, 来自微信的伴侣圈, title_pos=center,width=1200, height=600)map.add(, a2, a1, maptype='china', is_visualmap=True, visual_text_color='#000',visual_range=[1, 8], is_label_show=True, symbol=diamon, label_pos=inside ) 
  18. map.show_config()  
  19. map.render(./area_data.HTML) 

最后的功效如下:

几十行代码让你知道伴侣圈都是什么样的伴侣

很是地准,作为一个飘过北、上、杭的“浪里白条”,除了田园河南,我的挚友根基齐集在上海、北京和杭州,什么时辰也可以到广深溜一波。

挚友本性署名词云说明

微信署名是相识一小我私人性格和立场的重要参考,想看看我的伴侣圈里的大神们都是走的文艺风,照旧小清爽,照旧大学霸… …话不多说,一试便知:jieba(结巴)是一个强盛的分词库,美满支持中文分词;wordcloud是一个基于Python的词云天生类库,很好用;matplotlib.pyplot是一些呼吁行气魄威风凛凛函数的荟萃,使matplotlib以相同于MATLAB的方法事变。每个pyplot函数对一幅图片(figure)做一些窜改:好比建设新图片,在图片建设一个新的作图地区(plotting area),在一个作图地区内画直线,给图添加标签(label)等:

  1. import reimport jieba  
  2. import wordcloud as wc  
  3. import numpy as np  
  4. import PIL.Image as Imageimport matplotlib.pyplot as pltsig  
  5. list=[]  
  6. for i in friends:  
  7. signature=i['Signature'].strip().replace(span,).replace(class,).replace(emoji,)  
  8. rep=re.compile(1fd+w*|[/=])  
  9. signature=rep.sub(,signature)  
  10. siglist.append(signature)  
  11. text=.join(siglist)  
  12. wordlist=jieba.cut(text,cut_all=True)  
  13. word_space_split= .join(wordlist)  
  14. coloring= np.array(Image.open(./1.jpg)) # 一张猴子图片,试了许多照片,照旧这个好 

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读