1. 使用到的库
① wxpy:初始化微信机器人
② openpyxl:保存微信好友数据为Excel表格
③ pyecharts:生成可视化的地图
④ wordcloud、matplotlib、jieba:生成词云图
【特别提醒】:pyecharts 库用的是0.5.x版本,而在 pip 中安装的为1.x.x版本,因此需要自行到【官网】中下载。
2. 基本功能
① 分析微信好友数据
② 生成词云图
③ 生成地图展示
3. 代码实现
此处使用类来实现
(1) 导入模块
# 导入模块 from wxpy import Bot import openpyxl from pyecharts import Map from wordcloud import WordCloud import matplotlib.pyplot as plt import jieba
(2) 初始化机器人和获取微信好友的源信息
此处调用 Bot() 方法,需要扫码登陆微信网页版,后续操作才能进行。
def __init__(self, ToExcelFile="", ToCityFile="", ToMapProvinceFile="", ToMapCityFile=""): ''' 初始化机器人和其他参数 ''' # 初始化机器人,需要扫码 self.bot = Bot() # 获取我所有的微信好友信息 - 存储基础信息(未处理) self.allFriends_Info = self.bot.friends() # 我的微信好友个数 self.allFriends_Num = len(self.allFriends_Info) # 保存微信好友信息的表格文件路径(.xlsx) self.ExcelFile = ToExcelFile # 保存城市词云图的文件路径(.png/.jpg) self.WCOfCityFile = ToCityFile # 保存省份地图的文件路径(.html) self.MapProvinceFile = ToMapProvinceFile # 其他可用参数 self.MapCityFile = ToMapCityFile # 自动调用run方法,使得在实例化对象后自动运行其他函数 self.run()
(3) 统计和处理微信好友的信息
除了列出的还有 个性签名、头像等其他属性。
def getFriendsInfo(self): ''' 获取微信好友的全部信息 ''' # 存储微信好友的信息(经过信息处理的) self.friendsInfo = [] # 定义列标题 self.infoTitle = ['NickName', 'RemarkName', 'Sex', 'Province', 'City'] for aFriend in self.allFriends_Info: # 获取昵称 NickName = aFriend.raw.get(self.infoTitle[0], None) # 获取备注 RemarkName = aFriend.raw.get(self.infoTitle[1], None) # 获取性别 Sex = {1:"男", 2:"女", 0:"其他"}.get(aFriend.raw.get(self.infoTitle[2], None), None) # 获取省份 Province = aFriend.raw.get(self.infoTitle[3], None) # 获取城市 City = aFriend.raw.get(self.infoTitle[4], None) lisTmp = [NickName, RemarkName, Sex, Province, City] self.friendsInfo.append(lisTmp)
(4) 保存微信好友的信息
在这保存为Excel表格,在代码中插入表头行,为了便于阅读。
def saveFriendsInfoAsExcel(self, ExcelName): ''' 保存微信好友的信息到 Excel 表格中 ''' # 生成openpyxl对象 workbook = openpyxl.Workbook() # 激活表格 sheet = workbook.active # 设置表格标题 sheet.title = 'WeChatFriendsInfo' # 填充列标题到第一行 for _ in range(len(self.infoTitle)): sheet.cell(row=1, column=_+1, value=self.infoTitle[_]) # 填充微信好友信息,从第二行开始 for i in range(self.allFriends_Num): for j in range(len(self.infoTitle)): sheet.cell(row=i+2, column=j+1, value=str(self.friendsInfo[i][j])) # 若文件名非空,则保存到该路径下 if ExcelName != "": workbook.save(ExcelName) print("> Save WeChat friends' information successfully!")
(5) 分析微信好友的信息
def quiteAnalyzeFriendsInfo(self): ''' 分析数据,一步到位,直接了当 ''' print(self.allFriends_Info.stats_text())
(6) 生成city词云图
def creatWordCloudOfCity(self, CityName): ''' 使用获取的数据生成city词云图 ''' # 获取所有的城市 cityStr = "" for i in range(self.allFriends_Num): if self.friendsInfo[i][4] not in cityStr: cityStr += " " + self.friendsInfo[i][4] #jieba库精确模式分词 wordlist = jieba.lcut(cityStr) cityStr = ' '.join(wordlist) # 加载背景图片 #cloud_mask = np.array(Image.open(BackGroundFile)) #设置词云图属性 font = r'C:\Windows\Fonts\simfang.ttf' # 设置字体路径 wc = WordCloud( background_color = 'black', # 背景颜色 #mask = cloud_mask, # 背景图片 max_words = 100, # 设置最大显示的词云数 font_path = font, # 设置字体形式(在本机系统中) height = 300, # 图片高度 width = 600, # 图片宽度 max_font_size = 100, # 字体最大值 random_state = 100, # 配色方案的种类 ) # 生成词云图 myword = wc.generate(cityStr) #展示词云图 plt.imshow(myword) plt.axis('off') plt.show() # 若文件名非空,则保存到该路径下 if CityName != "": #保存词云图 wc.to_file(CityName) print("> Creat WeChat wordcloud of city successfully!")
(7) 生成province地图
def creatMapProvince(self, MapFile): ''' 使用获取的数据生成province地图 ''' # 获取所有省份 provinceList, provinceNum = [], [] for i in range(self.allFriends_Num): if self.friendsInfo[i][3] not in provinceList: provinceList.append(self.friendsInfo[i][3]) provinceNum.append(0) for i in range(self.allFriends_Num): for j in range(len(provinceList)): if self.friendsInfo[i][3] == provinceList[j]: provinceNum[j] += 1 # 生成 Map map = Map("各省微信好友分布", width=1000, height=800) map.add("", provinceList, provinceNum, maptype="china", is_visualmap=True, visual_text_color='#000') # 若文件名非空,则保存到该路径下 if MapFile != "": map.render(MapFile) print("> Creat WeChat Map of Provinces seccessfully!")
(8) 生成city地图
def creatMapCity(self, MapFile): ''' 使用获取的数据生成city地图 ''' # 获取所有省份 CityList, CityNum = [], [] for i in range(self.allFriends_Num): if self.friendsInfo[i][4] not in CityList: CityList.append(self.friendsInfo[i][4]) CityNum.append(0) for i in range(self.allFriends_Num): for j in range(len(CityList)): if self.friendsInfo[i][4] == CityList[j]: CityNum[j] += 1 for i in range(len(CityList)): CityList[i] += '市' # 生成 Map map = Map("各市微信好友分布", width=1000, height=800) map.add("", CityList, CityNum, maptype="广东", is_visualmap=True, visual_text_color='#000') # 若文件名非空,则保存到该路径下 if MapFile != "": map.render(MapFile) print("> Creat WeChat Map of Cities seccessfully!")
有了上述实现各个功能的方法,那么就差一个调用各种方法的方法了。
(9) run方法
def run(self): # 获取微信好友信息 self.getFriendsInfo() print("> Get WeChat friends' information successfully!") print("> Members:", self.allFriends_Num) # 保存微信好友信息 self.saveFriendsInfoAsExcel(self.ExcelFile) # 分析微信好友信息 self.quiteAnalyzeFriendsInfo() # 使用微信好友的 city 产生词云图 self.creatWordCloudOfCity(self.WCOfCityFile) # 生成微信好友的 province 地图 self.creatMapProvince(self.MapProvinceFile) # 生成微信好友的 city 地图 self.creatMapCity(self.MapCityFile)
对于文件路径,在main函数中传递即可。【注】:上述代码都在类中,在此处结束,下面为main函数
if __name__ == "__main__": ToExcelFile = "./WeChatAnalyze//FriendsInfo.xlsx" # 微信好友信息的Excel表格保存路径 ToPictureFile = "./WeChatAnalyze//CityWordCloud.png" # 微信好友信息city词云图保存路径 ToMapFileProvince = "./WeChatAnalyze//WeChatProvinceMap.html" # 微信好友信息province地图保存路径 ToMapFileCity = "./WeChatAnalyze//WeChatCityMap.html" # 微信好友信息city地图保存路径 # WeChatRobot对象实例化 robot = WeChatRobot(ToExcelFile, ToPictureFile, ToMapFileProvince, ToMapFileCity)
是不是觉得Main函数很简短,哈哈,没错,就是这么简!
接下来看看实现的效果吧!
> 这个是终端显示效果
> 这个是保存为Excel表格的内容
> 这个是微信好友各省的分布
> 这个是微信好友各市的分布
完整代码
# -*- coding: utf-8 -*- ''' This is a program which can analyze datas of WeChat friends. @author: bpf ''' # 导入模块 from wxpy import Bot import openpyxl from pyecharts import Map from wordcloud import WordCloud import matplotlib.pyplot as plt import jieba class WeChatRobot: '''====================== 1. 获取微信好友信息 ======================''' def __init__(self, ToExcelFile="", ToCityFile="", ToMapProvinceFile="", ToMapCityFile=""): ''' 初始化机器人和其他参数 ''' # 初始化机器人,需要扫码 self.bot = Bot() # 获取我所有的微信好友信息 - 存储基础信息(未处理) self.allFriends_Info = self.bot.friends() # 我的微信好友个数 self.allFriends_Num = len(self.allFriends_Info) # 保存微信好友信息的表格文件路径(.xlsx) self.ExcelFile = ToExcelFile # 保存城市词云图的文件路径(.png/.jpg) self.WCOfCityFile = ToCityFile # 保存省份地图的文件路径(.html) self.MapProvinceFile = ToMapProvinceFile # 其他可用参数 self.MapCityFile = ToMapCityFile # 自动调用run方法,使得在实例化对象后自动运行其他函数 self.run() '''====================== 2. 统计微信好友信息 ======================''' def getFriendsInfo(self): ''' 获取微信好友的全部信息 ''' # 存储微信好友的信息(经过信息处理的) self.friendsInfo = [] # 定义列标题 self.infoTitle = ['NickName', 'RemarkName', 'Sex', 'Province', 'City'] for aFriend in self.allFriends_Info: # 获取昵称 NickName = aFriend.raw.get(self.infoTitle[0], None) # 获取备注 RemarkName = aFriend.raw.get(self.infoTitle[1], None) # 获取性别 Sex = {1:"男", 2:"女", 0:"其他"}.get(aFriend.raw.get(self.infoTitle[2], None), None) # 获取省份 Province = aFriend.raw.get(self.infoTitle[3], None) # 获取城市 City = aFriend.raw.get(self.infoTitle[4], None) lisTmp = [NickName, RemarkName, Sex, Province, City] self.friendsInfo.append(lisTmp) '''====================== 3. 保存微信好友信息 ======================''' def saveFriendsInfoAsExcel(self, ExcelName): ''' 保存微信好友的信息到 Excel 表格中 ''' # 生成openpyxl对象 workbook = openpyxl.Workbook() # 激活表格 sheet = workbook.active # 设置表格标题 sheet.title = 'WeChatFriendsInfo' # 填充列标题到第一行 for _ in range(len(self.infoTitle)): sheet.cell(row=1, column=_+1, value=self.infoTitle[_]) # 填充微信好友信息,从第二行开始 for i in range(self.allFriends_Num): for j in range(len(self.infoTitle)): sheet.cell(row=i+2, column=j+1, value=str(self.friendsInfo[i][j])) # 若文件名非空,则保存到该路径下 if ExcelName != "": workbook.save(ExcelName) print("> Save WeChat friends' information successfully!") '''====================== 4. 分析微信好友信息 ======================''' def quiteAnalyzeFriendsInfo(self): ''' 分析数据,一步到位,直接了当 ''' print(self.allFriends_Info.stats_text()) '''====================== 5. 产生city词云图 ======================''' def creatWordCloudOfCity(self, CityName): ''' 使用获取的数据生成city词云图 ''' # 获取所有的城市 cityStr = "" for i in range(self.allFriends_Num): if self.friendsInfo[i][4] not in cityStr: cityStr += " " + self.friendsInfo[i][4] #jieba库精确模式分词 wordlist = jieba.lcut(cityStr) cityStr = ' '.join(wordlist) # 加载背景图片 #cloud_mask = np.array(Image.open(BackGroundFile)) #设置词云图属性 font = r'C:\Windows\Fonts\simfang.ttf' # 设置字体路径 wc = WordCloud( background_color = 'black', # 背景颜色 #mask = cloud_mask, # 背景图片 max_words = 100, # 设置最大显示的词云数 font_path = font, # 设置字体形式(在本机系统中) height = 300, # 图片高度 width = 600, # 图片宽度 max_font_size = 100, # 字体最大值 random_state = 100, # 配色方案的种类 ) # 生成词云图 myword = wc.generate(cityStr) #展示词云图 plt.imshow(myword) plt.axis('off') plt.show() # 若文件名非空,则保存到该路径下 if CityName != "": #保存词云图 wc.to_file(CityName) print("> Creat WeChat wordcloud of city successfully!") '''===================== 6. 产生province地图 =====================''' def creatMapProvince(self, MapFile): ''' 使用获取的数据生成province地图 ''' # 获取所有省份 provinceList, provinceNum = [], [] for i in range(self.allFriends_Num): if self.friendsInfo[i][3] not in provinceList: provinceList.append(self.friendsInfo[i][3]) provinceNum.append(0) for i in range(self.allFriends_Num): for j in range(len(provinceList)): if self.friendsInfo[i][3] == provinceList[j]: provinceNum[j] += 1 # 生成 Map map = Map("各省微信好友分布", width=1000, height=800) map.add("", provinceList, provinceNum, maptype="china", is_visualmap=True, visual_text_color='#000') # 若文件名非空,则保存到该路径下 if MapFile != "": #map.show_config() map.render(MapFile) print("> Creat WeChat Map of Provinces seccessfully!") '''===================== 7. 产生city地图 =====================''' def creatMapCity(self, MapFile): ''' 使用获取的数据生成city地图 ''' # 获取所有省份 CityList, CityNum = [], [] for i in range(self.allFriends_Num): if self.friendsInfo[i][4] not in CityList: CityList.append(self.friendsInfo[i][4]) CityNum.append(0) for i in range(self.allFriends_Num): for j in range(len(CityList)): if self.friendsInfo[i][4] == CityList[j]: CityNum[j] += 1 for i in range(len(CityList)): CityList[i] += '市' # 生成 Map map = Map("各市微信好友分布", width=1000, height=800) map.add("", CityList, CityNum, maptype="广东", is_visualmap=True, visual_text_color='#000') # 若文件名非空,则保存到该路径下 if MapFile != "": map.render(MapFile) print("> Creat WeChat Map of Cities seccessfully!") '''===================== 8. 自动执行函数 =====================''' def run(self): # 获取微信好友信息 self.getFriendsInfo() print("> Get WeChat friends' information successfully!") print("> Members:", self.allFriends_Num) # 保存微信好友信息 self.saveFriendsInfoAsExcel(self.ExcelFile) # 分析微信好友信息 self.quiteAnalyzeFriendsInfo() # 使用微信好友的 city 产生词云图 self.creatWordCloudOfCity(self.WCOfCityFile) # 生成微信好友的 province 地图 self.creatMapProvince(self.MapProvinceFile) # 生成微信好友的 city 地图 self.creatMapCity(self.MapCityFile) if __name__ == "__main__": ToExcelFile = "./WeChatAnalyze//FriendsInfo.xlsx" # 微信好友信息的Excel表格保存路径 ToPictureFile = "./WeChatAnalyze//CityWordCloud.png" # 微信好友信息city词云图保存路径 ToMapFileProvince = "./WeChatAnalyze//WeChatProvinceMap.html" # 微信好友信息province地图保存路径 ToMapFileCity = "./WeChatAnalyze//WeChatCityMap.html" # 微信好友信息city地图保存路径 # WeChatRobot对象实例化 robot = WeChatRobot(ToExcelFile, ToPictureFile, ToMapFileProvince, ToMapFileCity)
以上就是用 python 进行微信好友信息分析的详细内容,更多关于python 微信信息分析的资料请关注其它相关文章!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 群星《继续微笑致敬许冠杰》[低速原抓WAV+CUE]
- 潘秀琼.2003-国语难忘金曲珍藏集【皇星全音】【WAV+CUE】
- 林东松.1997-2039玫瑰事件【宝丽金】【WAV+CUE】
- 谭咏麟.2022-倾·听【环球】【WAV+CUE】
- 4complete《丛生》[320K/MP3][85.26MB]
- 4complete《丛生》[FLAC/分轨][218.01MB]
- 羽泉《给未来的你&天黑天亮》[WAV+CUE][968M]
- 庄心妍《我也许在等候》[低速原抓WAV+CUE]
- 王雅洁《小调歌后2》[原抓WAV+CUE]
- 中国武警男声合唱团《辉煌之声1天路》[DTS-WAV分轨]
- 紫薇《旧曲新韵》[320K/MP3][175.29MB]
- 紫薇《旧曲新韵》[FLAC/分轨][550.18MB]
- 周深《反深代词》[先听版][320K/MP3][72.71MB]
- 李佳薇.2024-会发光的【黑籁音乐】【FLAC分轨】
- 后弦.2012-很有爱【天浩盛世】【WAV+CUE】