如何根据字典中值的大小,对字典中的项排序 sorted(dict2.iteritems(),key=lambda item:item[1],reverse=True)
使用内置函数sorted
1.利用zip将字典数据转换成为元组
print sorted(zip(dict2.itervalues(),dict2.iterkeys()),reverse=True)
2.传递sorted函数的key参数
sorted(dict2.iteritems(),key=lambda x:x[1],reverse=True)
3.可以重新获得已经排序的字典
dict(sorted(dict2.iteritems(),key=lambda x:x[1],reverse=True))
《命运》和《寻梦》都是著名科幻作家倪匡的科幻作品。
这里给出一个《命运》和《寻梦》的网络版本,文件名为“命运-网络版.txt”和“寻梦-网络版.txt”。
问题1:请编写程序,对这两个文本中出现的字符进行统计,
字符与出现次数之间用冒号:分隔,
将两个文件前 100 个最常用字符分别输出保存到“命运-字符统计.txt”和“寻梦-字符统计.txt”文件中,
该文件要求采用 CSV 格式存储,参考格式如下(注意,不统计回车字符):
names = ["命运","寻梦"]
for name in names:
fi = open(name+"-网络版.txt",'r',encoding="utf-8")
fo = open(name+"--字符统计.txt",'w',encoding = "utf - 8")
txt = fi.read()
d = {}
for c in txt:
d[c] = d.get(c,0)+1
del d['\n']
ls.list(d.items())
ls.sort(key=lambda x:x[1],reverse=True)
for i in range(100):
ls[i] = "{}:{}".format(ls[i][0],ls[i][1])
fo.write(",".join(ls[:100]))
fi.close()
fo.close()
方法一:
import random
dict2 = {k:random.randint(-100,100) for k in xrange(340,350)}
print dict2
print sorted(zip(dict2.itervalues(),dict2.iterkeys()),reverse=True)
方法二:
import random
dict2 = {k:random.randint(-100,100) for k in xrange(340,350)}
print sorted(dict2.iteritems(),key=lambda item:item[1],reverse=True)
newdict2 = dict(sorted(dict2.iteritems(),key=lambda item:item[1],reverse=True))
print newdict2
help(sorted)
>>> help(sorted)
Help on built-in function sorted in module __builtin__:
sorted(...)
sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list
>>>
>>>
>>>
>>> dir(sorted)
['__call__', '__class__', '__cmp__', '__delattr__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__le__', '__lt__', '__module__', '__name__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__self__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__']