第一个微信小项目

Posted hjy567jiayouya

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第一个微信小项目相关的知识,希望对你有一定的参考价值。

微信,已经成为人们必不可少的社交工具。每个人的微信里都有形形色色的人,你了解他们吗?他们又来自哪呢?

今天我们就来编写一个关于好友分析的代码

下载依赖库

在此之前,我们需要下载七个库:Pillow、Pyecharts、Itchat、Jieba、Numpy、Pandas、wxpy

打开Anaconda Prompt,输入如下代码,分别安装不同库:(安装结果就不展示)

安装 wxpy: pip install wxpy 

安装 PIL: pip install pillow

安装 pyecharts:pip install pyecharts

安装 Itchat: pip install itchat

安装 Jieba: pip install jieba

安装 Pandas:pip install Pandas

安装 Numpy:pip install Numpy

安装地图数据包:pip install echarts-china-provinces-pypkgpip install echarts-countries-pypkg

运行

1.登陆微信

输入此代码,会自动弹出二维码

#导入模块
from wxpy import *
#初始化机器人,选择缓存模式(扫码)登录
bot = Bot(cache_path=True)
#获取我的所有微信好友信息
friend_all = bot.friends()

手机同意,便可获取微信好友的相关信息(登陆成功如图)

技术图片

2.获取信息

输入

print(friend_all[0].raw) #friend_all[0]是我的微信昵称,.raw 则是获取我的全部信息 

得到关于我的信息(如图)

技术图片

如何获取好友信息,并做成表格,输入代码:

lis=[] 
for a_friend in friend_all:
     NickName = a_friend.raw.get(NickName,None)
     #Sex = a_friend.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)
     Signature = a_friend.raw.get(Signature,None)
     HeadImgUrl = a_friend.raw.get(HeadImgUrl,None)
     HeadImgFlag  = a_friend.raw.get(HeadImgFlag,None)
     list_0=[NickName,Sex,City,Province,Signature,HeadImgUrl,HeadImgFlag]
     lis.append(list_0)
#编写列表
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(pyq,lis)

结果:

技术图片

技术图片

3.数据分析

有这么多好友,想清楚知道自己的好友分布、性别占比等数据,现在输入如下代码,立刻明了:

Friends = bot.friends()
data = Friends.stats_text(total=True, sex=True, top_provinces=30, top_cities=500)
print(data)

from pandas import read_excel
df = read_excel(pyq.xlsx,sheet_name=list2excel07)
df.tail(5)
df.city.count()
df.city.describe() 

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()

滴~结果:

技术图片技术图片

诶,可以做一个词云图哦~输入代码:

#利用 pyecharm 做词云 
import pandas as pd
#count = df.city.value_counts()
#对 dataframe 进行全频率统计,排除了 nan 
city_list = df[city].fillna(NAN).tolist()#将 dataframe 的列转化为 list,其中的 nan 用“NAN” 替换 
count_city = pd.value_counts(city_list)#对 list 进行全频率统计 
 
import matplotlib.pyplot as plt
from pandas import DataFrame
from wordcloud 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(rc:\\Users\\HJY\\.spyder-py3\\wc1.html)

滴~

技术图片

这张图展示了我的某些地方好友多

我也可以将微信好友分布在地图上,嘻嘻(代码如下)

#将这些好友在全国地图上做分布
province_list = df[province].fillna(NAN).tolist()#将 dataframe 的列转化为 list,其中的 nan 用 “NAN”替换
count_province = pd.value_counts(province_list)#对 list 进行全频率统计
from pyecharts import Map
value =count_province.tolist()
attr =count_province.index.tolist()
map=Map("各省微信好友分布", width=1200, height=600)
map.add("", attr, value, maptype=china, is_visualmap=True,visual_text_color=#000, is_label_show = True)  #显示地图上的省份
map.show_config()
map.render(rc:\\Users\\HJY\\.spyder-py3\\me\\map1.html) 

滴滴

技术图片

The end......(下次邀请微信小机器人,嘿嘿嘿)

以上是关于第一个微信小项目的主要内容,如果未能解决你的问题,请参考以下文章

微信小程序第七天WXML语法之模板用法

微信小程序代码片段分享

第一个微信小项目

微信小程序海报 uniapp

微信小程序海报 uniapp

一个小程序的后台是web端