亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python制作動態詞頻條形圖的過程是怎樣的

發布時間:2021-11-11 21:06:02 來源:億速云 閱讀:128 作者:柒染 欄目:開發技術

這篇文章給大家介紹Python制作動態詞頻條形圖的過程是怎樣的,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

前言

”數據可視化“這個話題,相信大家并不陌生,在一些平臺,經常可以看到一些動態條形圖的視頻,大多都是某國家 GDP 的變化或者不同國家疫情中感染人數的變化等等。

這篇文章,我們將使用 Python 繪制動態詞頻條形圖,顧名思義,就是以詞頻作為數量指標的動態條形圖。

前期準備

輸入以下命令,安裝必須的庫:

pip install JiashuResearchTools
pip install jieba
pip install pandas
pip install bar_chart_race

數據的選擇與獲取

我們這次使用的數據是簡書文章收益排行榜,日期范圍為 2020 年 6 月 20 日至 2021 年 9 月 18 日。

Python制作動態詞頻條形圖的過程是怎樣的

從網頁中解析數據的過程較為復雜,我們使用簡書數據科學庫 JianshuResearchTools 完成。

為方便調試,我們使用 Jupyter Notebook 進行交互式開發。

導入 JianshuResearchTools,并為其設置別名:

import JianshuResearchTools as jrt

調用接口,獲取 2021 年 9 月 17 日的數據:

jrt.rank.GetArticleFPRankData("20210917")

返回的數據如下:

[{'ranking': 0,
  'aslug': 'a03adf9d5dd5',
  'title': '幸得君心似我心',
  'author_name': '雁陣驚寒',
  'author_avatar_url': 'https://upload.jianshu.io/users/upload_avatars/26225608/682b892e-6661-4f98-9aab-20b4038a433b.jpg',
  'fp_to_author': 3123.148,
  'fp_to_voter': 3123.148,
  'total_fp': 6246.297},
 {'ranking': 1,
  'aslug': '56f7fe236842',
  'title': '傷痕',
  'author_name': '李文丁',
  'author_avatar_url': 'https://upload.jianshu.io/users/upload_avatars/26726969/058e18c4-908f-4710-8df7-1d34d05d61e3.jpg',
  'fp_to_author': 1562.198,
  'fp_to_voter': 1562.198,
  'total_fp': 3124.397},
 (以下省略)

可以看出,返回的數據中包含文章的排名、標題、作者名、作者頭像鏈接和關于簡書資產的一些信息。

我們只需要文章的標題進行統計,所以我們將上面獲取到的數據賦值給變量 raw_data,然后:

[item["title"] for item in raw_data]

使用列表推導式,我們得到了文章標題組成的列表。

為方便處理,我們將這些數據連接起來,中間用空格分隔:

" ".join([item["title"] for item in raw_data])

但是我們遇到了報錯:

TypeError: sequence item 56: expected str instance, NoneType found

從報錯信息中可以看出,我們獲取到的文章標題列表中有空值,導致字符串的連接失敗了。

(空值是因為作者刪除了文章)

所以我們還需要加入去除空值的邏輯,代碼編程這樣:

" ".join(filter(None, [item["title"] for item in raw_data]))

filter 函數在第一個參數為 None 時,默認過濾掉列表中的空值。

現在我們獲取到的數據如下:

'幸得君心似我心 傷痕 短篇|阿生 “我最喜愛的友友”大評選|理事會 · 中秋嘉年華,等你來! 是緣是劫無須問,石火窮年一蝶迷 職業日記|從蜜月到陌路:我和美國外教的一點事 紅樓||淺談《紅樓夢》開篇一頑石 城市印象|走筆八卦城 花豹與狗的愛情終結在人與動物的戰爭里(以下省略)

接下來,我們需要獲取時間范圍內的所有數據。

查詢 JRT 的函數文檔可知,我們需要一個字符串類型,格式為”YYYYMMDD“的參數表示目標數據的日期。

所以我們需要寫一段程序,用于實現這些日期字符串的生成,代碼如下:

from datetime import date, timedelta
def DateStrGenerator():
    start_date = date(2020, 6, 20)
    after = 0
    result = None
    while result != "20210917":
        current_date = start_date + timedelta(days=after)
        result = current_date.strftime(r"%Y%m%d")
        yield result
        after += 1

接下來,我們編寫一段代碼,實現對這些數據的獲取:

result = []
for current_date in tqdm(DateStrGenerator(), total=455):
    raw_data = jrt.rank.GetArticleFPRankData(current_date)
    processed_data = " ".join(filter(None, [item["title"] for item in raw_data]))
    result.append({"date": current_date, 
                   "data": processed_data})

這里使用 tqdm 庫顯示了一個進度條,非必須。

使用 Pandas 庫,將我們采集到的數據轉換成 DataFrame:

df = pandas.DataFrame(result)

Python制作動態詞頻條形圖的過程是怎樣的

Python制作動態詞頻條形圖的過程是怎樣的

分詞

我們使用 jieba 庫實現分詞,先嘗試對第一條數據進行處理:

jieba.lcut(df["data"][0])

使用 Python 標準庫 collections 中的 Counter 進行詞頻統計:

Counter(jieba.lcut(df["data"][0]))

簡單畫個條形圖:

Python制作動態詞頻條形圖的過程是怎樣的

可以看到,空格和一些標點符號,包括”的“、”我“之類無意義詞匯出現頻率很高,我們需要將它們剔除出去。

我們構建一個存放停用詞的 txt 文檔,之后使用如下代碼將其讀取,并轉換成一個列表:

stopwords_list = [item.replace("\n", "") for item in open("stopwords.txt", "r", encoding="utf-8").readlines()]

接下來,編寫一個函數,實現停用詞的剔除,為了方便后續的數據處理,我們也一并剔除單字和只出現一次的詞語:

def process_words_count(count_dict):
    result = {}
    for key, value in count_dict.items():
        if value < 2:
            continue
        if len(key) >= 2 and key not in stopwords_list:
            result[key] = value
    return result

另外,我們使用 jieba 庫的 add_word 函數將一些簡書中的組織名和專有名詞添加到詞庫中,從而提高分詞的準確性,代碼如下:

keywords_list = [item.replace("\n", "") for item in open("keywords.txt", "r", encoding="utf-8").readlines()]
for item in keywords_list:
    jieba.add_word(item)

經過一番處理,現在分詞效果有了明顯的改善:

Python制作動態詞頻條形圖的過程是怎樣的

最后,用這段代碼對所有數據進行分詞,并將結果保存到另一個 DataFrame 中:

data_list = []
date_list = []
for _, item in df.iterrows():
    date_list.append(datetime(int(item["date"][0:4]), int(item["date"][4:6]), int(item["date"][6:8])))
    data_list.append(process_words_count(Counter(jieba.lcut(item["data"]))))
processed_df = pandas.DataFrame(data_list, index=date_list)

我最終得到的結果是一個 455 行,2087 列的 DataFrame。

Python制作動態詞頻條形圖的過程是怎樣的

篩選與可視化

這樣多的數據,其中很大一部分都不能代表整體情況,所以我們需要進行數據篩選。

使用以下代碼,統計所有列數值的總和,即每個關鍵詞在全部數據中出現的次數,存儲到名為 sum 的行中:

try:
    result = []
    for i in range(3000):
        result.append(processed_df.iloc[:, i].sum())
except IndexError:
    processed_df.loc["sum"] = result

Python制作動態詞頻條形圖的過程是怎樣的

運行以下代碼,只保留在數據集中出現 300 次以上的關鍵詞:

maller_df = processed_df.T[processed_df.T["sum"] >= 300].T
smaller_df = smaller_df.drop(labels="sum")
smaller_df.columns

現在,數據集中的列數減少到了 24 個,可以進行可視化了。

不要忘記先導入模塊:

import bar_chart_race as bcr

使用此模塊需要先安裝 ffmpeg,這方面教程可以自行查找。

另外,為了支持中文顯示,我們需要打開這個模塊下的 _make_chart.py 文件,在 import 之后增加以下兩行代碼:

plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False

這兩行代碼將會把 matplotlib 的默認字體替換成支持中文顯示的字體。

最后,使用一行代碼完成可視化:

bcr.bar_chart_race(smaller_df, steps_per_period=30, period_length=1500, title="簡書文章收益排行榜可視化", bar_size=0.8, fixed_max=10, n_bars=10)

在這行代碼中,我們使用 smaller_df 作為數據集,輸出文件為 output.mp4,幀率設置為 30,每行數據顯示 2 秒。

由于數據較多,這一步時間較長,而且會占用較多內存。運行結束后,即可在目錄中找到輸出的文件。

Python制作動態詞頻條形圖的過程是怎樣的

關于Python制作動態詞頻條形圖的過程是怎樣的就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

昌邑市| 宝山区| 西丰县| 满城县| 伊春市| 右玉县| 上虞市| 永吉县| 济阳县| 安庆市| 崇阳县| 北安市| 无棣县| 吉水县| 繁峙县| 当雄县| 荣成市| 剑阁县| 龙胜| 屏山县| 迭部县| 蓝山县| 新河县| 大邑县| 呼玛县| 易门县| 海门市| 西畴县| 广南县| 清流县| 桑日县| 海林市| 临漳县| 宜阳县| 双辽市| 寻乌县| 余姚市| 涿鹿县| 龙岩市| 津市市| 册亨县|