python读取JSON,txt文件,依据字典(dict)分析词频绘制词云(wordcloud)

python读取JSON,txt文件,生成字典(dict),分析词频绘制词云

一、读取JSON、txt文件

1、JSON与txt文件保存字典格式的区别

字典格式:

{

	"key1":"value1",

	"key2":"value2",
    .........

}
  • JSON文件在保存字典时,如果重复写入相同的key对应的value时会覆盖之前的value。

  • txt文件在保存字典时,换行保存一个新的字典格式。

2、读取方法
  • 读取txt文件(包含多个字典),并合并字典。

    import json
    import numpy as np
    
    
    f = open("../hotMsg.txt","r")
    line = f.readline()
    count = 1
    while line:
        # print(count,ls)
        data = f.readline()
        data = json.loads(data)
        ls.append(data)
        count += 1
        line = f.readline()
    for item in ls:
        for key in item.keys():
            if key in dic.keys():
                dic[key] += int(item[key])
            else:
                dic[key] = int(item[key])
    
  • 读取json文件。

    import json
    with open("../hotMsg.json","r",encoding='UTF-8') as f:
    	load_dict = json.load(f)
    

二、使用jieba库分析词频

import jieba as jieba
import jieba.analyse as analyse

words_count_list = jieba.analyse.textrank(' '.join(dic.keys()), topK=50, withWeight=True)
dic = dict(words_count_list)

三、凭借字典(词频)生成词云

import wordcloud
from matplotlib import pyplot as plt
from PIL import Image

mask = np.array(Image.open('../wordcloud.png')) # 定义词频背景
wc = wordcloud.WordCloud(
    background_color=(255,255,255),
    font_path='../msyh.ttf', # 设置字体格式
    mask=mask, # 设置背景图
    max_words=200, # 最多显示词数
    max_font_size=45 # 字体最大值
)

wc.generate_from_frequencies(dic)
plt.imshow(wc) # 显示词云
plt.axis('off') # 关闭坐标轴
plt.show() # 显示图像

在这里插入图片描述
在这里插入图片描述

  • 3
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

图南zzz

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值