脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Python - Python导出并分析聊天记录详解流程

Python导出并分析聊天记录详解流程

2022-10-07 13:41落伍的码农 Python

这篇文章主要介绍了Python将QQ聊天记录生成词云的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

导出聊天记录生成词云看看你和对象聊了什么(可惜我没女朋友)

1.导出聊天记录打开消息管理器

Python导出并分析聊天记录详解流程

导出的格式选择txt格式(我这里选择导出的路径是桌面所以在桌面上生成了一个包含聊天记录的.txt文件)

Python导出并分析聊天记录详解流程

2.编写代码图中框出来的文本是我们不需要的(比如说图片会在这里面显示为[图片]表情显示为[表情]) 所以我们把它替换掉,我这里用到了正则:

Python导出并分析聊天记录详解流程

string = open(r"C:Usersl1768Desktop消息记录.txt","r",encoding="utf-8").read()
s = re.compile("2020.+洋仔|2020.+✎﹏ℳ๓ 大大大威锅丶|表情|图片|2019.+洋仔|2019.+✎﹏ℳ๓ 大大大威锅丶|撤回了一条消息|系统消息")#编写正则表达式
message = re.sub(s,"",string)#替换对应的字符串为空字符串

然后我们把经过处理的文本再进行去除特殊字符处理

def getText(text):#该函数用来替换文本中出现的特殊字符
txt = text
for ch in "!"#$%&()*+,-./:;<=>?@[]^_‘{|}~,。、 :":
txt = txt.replace(ch, "")   #将文本中特殊字符替换为空格
return txt
message = getText(message)

使用jieba分词并生成词云

split_message = jieba.lcut(message)
wordcloud_txt = " ".join(split_message)
w=wordcloud.WordCloud(background_color="white", 
font_path="./fonts/simhei.ttf",
width=1600,height=800,
max_words=2000)#设置生成词云的参数,background_color指定图片背景颜色,
#font_path设置中文字体,要不然中文会显示不出来
#width=1600,height=800分别指定图片的宽度像素和高度像素,
#max_words指定生成词云的词最大是两千词
#还有很多可选参数,大家可以自行百度
w.generate(wordcloud_txt)#向词云传递文本
w.to_file("聊天记录词云.png")#最后生成词云的图片

3.最终生成的结果:

Python导出并分析聊天记录详解流程

4.完整代码:

import re
import jieba
import wordcloud
def getText(text):#该函数用来替换文本中出现的特殊字符
txt = text
for ch in "!"#$%&()*+,-./:;<=>?@[]^_‘{|}~,。、 :":
txt = txt.replace(ch, "") #将文本中特殊字符替换为空格
return txt
string = open(r"C:Usersl1768Desktop消息记录.txt","r",encoding="utf-8").read()
s = re.compile("2020.+洋仔|2020.+✎﹏ℳ๓ 大大大威锅丶|表情|图片|2019.+洋仔|2019.+✎﹏ℳ๓ 大大大威锅丶|撤回了一条消息|系统消息")
message = re.sub(s,"",string)
message = getText(message)
split_message = jieba.lcut(message)
wordcloud_txt = " ".join(split_message)
w=wordcloud.WordCloud(background_color="white", font_path="./fonts/simhei.ttf",width=1600,height=800,max_words=2000)#设置生成词云的参数
w.generate(wordcloud_txt)#向词云传递文本
w.to_file("聊天记录词云.png")#最后生成词云的图片

到此这篇关于Python导出并分析聊天记录详解流程的文章就介绍到这了,更多相关Python 分析聊天记录内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/Python_shannian/article/details/122937809

延伸 · 阅读

精彩推荐
  • PythonPython科学计算之Pandas详解

    Python科学计算之Pandas详解

    Pandas 是 python 的一个数据分析包,属于PyData项目的一部分。下面这篇文章主要介绍了Python中科学计算之Pandas,需要的朋友可以参考借鉴,下面来一起学习学习...

    栖迟於一丘2122020-09-17
  • Python在scrapy中使用phantomJS实现异步爬取的方法

    在scrapy中使用phantomJS实现异步爬取的方法

    今天小编就为大家分享一篇在scrapy中使用phantomJS实现异步爬取的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    郎总4022021-04-30
  • PythonPython轻量级循环-列表推导式

    Python轻量级循环-列表推导式

    Python 列表推导式(list comprehension)利用其他列表创建新的列表,工作方式类似于for循环,使用列表推导式可以快速生成一个列表,或者根据某个列表生成满足...

    AI入门学习4422021-03-02
  • PythonPython实现socket库网络通信套接字

    Python实现socket库网络通信套接字

    socket又叫套接字,实现网络通信的两端就是套接字。分为服务器对应的套接字和客户端对应的套接字,本文给大家介绍Python实现socket库网络通信套接字的相...

    一天一篇Python库9172021-11-23
  • Pythonmatplotlib简介,安装和简单实例代码

    matplotlib简介,安装和简单实例代码

    这篇文章主要介绍了matplotlib简介,安装和简单实例代码,具有一定借鉴价值,需要的朋友可以参考下。...

    踏破凌霄城5562020-12-29
  • PythonPython Tkinter对话框控件使用详解

    Python Tkinter对话框控件使用详解

    Tkinter中提供了三种对话框控件:文件选择对话框、颜色选择对话框和消息对话框。本文将具体为大家介绍一下这三种对话框的使用,需要的可以参考一下...

    严长生7572022-08-29
  • PythonPython中使用Tkinter模块创建GUI程序实例

    Python中使用Tkinter模块创建GUI程序实例

    这篇文章主要介绍了Python中使用Tkinter模块创建GUI程序实例,本文给出了创建窗口、文本框、按钮等实例,需要的朋友可以参考下 ...

    脚本之家4442020-05-18
  • PythonPython用csv写入文件_消除空余行的方法

    Python用csv写入文件_消除空余行的方法

    今天小编就为大家分享一篇Python用csv写入文件_消除空余行的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    YouthDance13572021-03-13