溫馨提示×

溫馨提示×

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

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

Python實現(xiàn)統(tǒng)計英文文章詞頻的方法分析

發(fā)布時間:2020-08-19 14:20:15 來源:腳本之家 閱讀:241 作者:蘇奇 欄目:開發(fā)技術(shù)

本文實例講述了Python實現(xiàn)統(tǒng)計英文文章詞頻的方法。分享給大家供大家參考,具體如下:

應用介紹:

統(tǒng)計英文文章詞頻是很常見的需求,本文利用python實現(xiàn)。

思路分析:

1、把英文文章的每個單詞放到列表里,并統(tǒng)計列表長度;
2、遍歷列表,對每個單詞出現(xiàn)的次數(shù)進行統(tǒng)計,并將結(jié)果存儲在字典中;
3、利用步驟1中獲得的列表長度,求出每個單詞出現(xiàn)的頻率,并將結(jié)果存儲在頻率字典中;
4、以字典鍵值對的“值”為標準,對字典進行排序,輸出結(jié)果(也可利用切片輸出頻率最大或最小的特定幾個,因為經(jīng)過排序sorted()函數(shù)處理后,單詞及其頻率信息已經(jīng)存儲在元組中,所有元組再組成列表。)

代碼實現(xiàn):

fin = open('The_Magic_Skin _Honore_de_Balzac.txt') #the txt is up
#to you
lines=fin.readlines()
fin.close()
'''transform the article into word list
'''
def words_list():
  chardigit='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789 '
  all_lines = ''
  for line in lines:
    one_line=''
    for ch in line:
      if ch in chardigit:
        one_line = one_line + ch
    all_lines = all_lines + one_line
  return all_lines.split()
'''calculate the total number of article list
s is the article list
'''
def total_num(s):
  return len(s)
'''calculate the occurrence times of every word
t is the article list
'''
def word_dic(t):
  fre_dic = dict()
  for i in range(len(t)):
    fre_dic[t[i]] = fre_dic.get(t[i],0) + 1
  return fre_dic
'''calculate the occurrence times of every word
w is dictionary of the occurrence times of every word
'''
def word_fre(w):
  for key in w:
    w[key] = w[key] / total
  return w
'''sort the dictionary
v is the frequency of words
'''
def word_sort(v):
  sort_dic = sorted(v.items(), key = lambda e:e[1])
  return sort_dic
'''This is entrance of functions
output is the ten words with the largest frequency
'''
total = total_num(words_list())
print(word_sort(word_fre(word_dic(words_list())))[-10:])

PS:這里再為大家推薦2款相關(guān)統(tǒng)計工具供大家參考:

在線字數(shù)統(tǒng)計工具:
http://tools.jb51.net/code/zishutongji

在線字符統(tǒng)計與編輯工具:
http://tools.jb51.net/code/char_tongji

更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python文件與目錄操作技巧匯總》、《Python文本文件操作技巧匯總》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進階經(jīng)典教程》

希望本文所述對大家Python程序設計有所幫助。

向AI問一下細節(jié)

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

AI