,如果你想要做的是那種你的列表,你可以使用
import operator
fdists = [(u'seeing', 2), (u'said.', 2), (u'one', 2), (u'death', 2), (u'entertainment', 2), (u'it\u2019s', 2), (u'weiss', 2), (u'read', 2), (u'\u201cit', 1), (u'shot', 1), (u'show\u2019s', 1), (u'people', 1), (u'dead,\u201d', 1), (u'bloody', 1)]
fdists2 = [(u'seeing', 3), (u'said.', 4), (u'one', 2), (u'death', 2), (u'entertainment', 2), (u'it\u2019s', 2), (u'weiss', 2), (u'read', 2)]
fdists += fdists2
fdict = {}
for i in fdists:
if i[0] in fdict:
fdict[i[0]] += i[1]
else:
fdict[i[0]] = i[1]
sorted_f = sorted(fdict.items(), key=operator.itemgetter(1), reverse=True)
print sorted_f[:30]
[(u'said.', 6), (u'seeing', 5), (u'death', 4), (u'entertainment', 4), (u'read', 4), (u'it\u2019s', 4), (u'weiss', 4), (u'one', 4), (u'\u201cit', 1), (u'shot', 1), (u'show\u2019s', 1), (u'people', 1), (u'dead,\u201d', 1), (u'bloody', 1)]
您可以處理重複的另一種方法是使用熊貓groupby()
功能,然後使用sort()
功能按count
和word
這樣排序
from pandas import *
import pandas as pd
fdists = [(u'seeing', 2), (u'said.', 2), (u'one', 2), (u'death', 2), (u'entertainment', 2), (u'it\u2019s', 2), (u'weiss', 2), (u'read', 2), (u'\u201cit', 1), (u'shot', 1), (u'show\u2019s', 1), (u'people', 1), (u'dead,\u201d', 1), (u'bloody', 1)]
fdists2 = [(u'seeing', 3), (u'said.', 4), (u'one', 2), (u'death', 2), (u'entertainment', 2), (u'it\u2019s', 2), (u'weiss', 2), (u'read', 2)]
fdists += fdists2
df = DataFrame(data = fdists, columns = ['word','count'])
df= DataFrame([{'word': k, 'count': (v['count'].sum())} for k,v in df.groupby(['word'])], columns = ['word','count'])
Sorted = df.sort(['count','word'], ascending = [0,1])
print Sorted[:30]
word count
8 said. 6
9 seeing 5
2 death 4
3 entertainment 4
4 it’s 4
5 one 4
7 read 4
12 weiss 4
0 bloody 1
1 dead,」 1
6 people 1
10 shot 1
11 show’s 1
13 「it 1
爲什麼你不用字典? – SirParselot
從一開始爲了捕獲每個唯一字的出現或在for循環之後? – Swan87
我嘗試使用collection.Counter從一開始,但它需要永遠執行.. – Swan87