小編這次要給大家分享的是Python如何實(shí)現(xiàn)中國地圖詞云圖,文章內(nèi)容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
站在用戶的角度思考問題,與客戶深入溝通,找到共和網(wǎng)站設(shè)計(jì)與共和網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:網(wǎng)站建設(shè)、做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名申請、雅安服務(wù)器托管、企業(yè)郵箱。業(yè)務(wù)覆蓋共和地區(qū)。熱詞圖很酷炫,也非常適合熱點(diǎn)事件,抓住重點(diǎn),以圖文結(jié)合的方式表現(xiàn)出來,很有沖擊力。下面這段代碼是制作熱詞圖的,用到了以下技術(shù):
jieba,把文本分詞
wordcloud,制作熱圖
chardet,辨別文件的編碼格式,其中中文統(tǒng)一為GB18030,更加的兼容
imageio,提取圖片的形狀
其他:自動(dòng)識(shí)別文件編碼,自動(dòng)識(shí)別txt文件,圖片文件名與txt文件一致,使用的是四大名著的文本(自行百度),部分中國地圖
上代碼:
import os import jieba import wordcloud import chardet import imageio directory = "D:\\" mask = imageio.imread(r"D:\map.jpg") # 用于最后圖像圖形 directory_lists = os.scandir(directory) for directory_list in directory_lists: if directory_list.is_dir() or directory_list.path.split('.')[-1] != "txt": continue with open(directory_list.path, 'rb') as fd: coding = chardet.detect(fd.read()[:1000])['encoding'] if coding.upper() == 'GB2312' or coding == 'GBK': coding = 'GB18030' file = open(directory_list.path, 'r', encoding=coding) text = file.read() file.close() jieba_text = ' '.join(jieba.lcut(text)) w = wordcloud.WordCloud(height=800, width=1600, font_path='msyh.ttc', background_color='white', stopwords={'Page'}, mask=mask) w.generate(jieba_text) w.to_file('{}.png'.format(directory_list.path.split('.')[0]))