字典是Python的一种数据结构,像数学中的映射集合,可以理解为由键和值成对存在的单元构成的一个列表。
一.字典构造形式:
1.字典名 = {键名1:值1 ,键名2:值2 ,键名3:值3}
例如 :Dic = {'op':55 , 3:('a','b') , 'q':[1.25,'score',5]}
其中键只能是不可改变对象(如元组,字符串,整数等)和值可以为任意的对象
2.可以使用dict()或{}构造一个空的字典如 Dic=dict() DIc={}
3.zip命令创建字典
创建2个列表一个用作键一个用作值
字典名 = dict(zip(键列表,值列表))
>>> keys = ["red","white","blue"] >>> values = [100,300,400] >>> Dic = dict(zip(keys,values)) >>> Dic {'red': 100, 'blue': 400, 'white': 300}
二.字典的索引:
1.字典可以使用 [ ] 运算符,但与之前的列表元组等不同,字典不可以使用顺序的数字作为索引如 1,2,-1等
2.字典需要使用键值作为索引,如1.的例子中,可以使用如下的索引方法 Dic['op'] Dic[3] Dic['q']
3.既然字典的值可以是任意对象,那么就有可能为列表,元组,甚至是字典。那么当值为上述对象时候,使用字典名[键值]方式将得到一个集合,由此我们可以使用一个二维的方法进行索引
范例:
>>> Dic={'a':{'q':'hello' , 'w':'how' , 'e':'Thanks'}} >>> Dic['a']['e'] 'Thanks'
一维结果为列表的话,二维的[]变可以使用顺序的数字索引
以此类推,当二维键所对应的值仍为字典等集合时,可以继续这样使用:
>>> Dic={'a':{'q':'hello' , 'w':'how' , 'e':{'u':'yes'}}} >>> Dic['a']['e']['u'] 'yes'
4.如果在索引时,输入的键值不存在,Python将报错
三.字典的赋值:
赋值方法为 字典名[键名] = 值 以此形成一个映射关系
当待赋值的键名不存在时,python将直接在该字典中加入此键值对
四.与字典有关的操作:
[]:在方括号中使用键进行索引
len():计算出的长度为字典中键值对的个数
in:成员测试,判断键是否在该字典中
for:循环找出字典中每个键值对
五.字典方法:
items() : 生成所有键值对的元组列表
keys() : 生成所有键的列表
values(): 生成所有值的列表
copy() : 对字典进行浅拷贝 (引用关系)
六.一个实例
以《葛底斯堡演说》为例进行分析,判断其中的单词数和对应的频率,并进行排序显示
import string def addword (word,Wdict): #将word单词加入字典统计,没有添加键值对,有则值+1 if(word in Wdict): Wdict[word]+=1 else: Wdict[word]=1 def collect(line,Wdict): #对line字符串进行分析,并拆分出有效单词加入到字典 line = line.strip() wordline = line.split() for word in wordline: if(word == '--'): continue word = word.strip(string.punctuation) word = word.lower() addword(word,Wdict) def Printf(Wdict): #对字典内容排序输出函数 resultwords = [[val,key] for key,val in Wdict.items()] resultwords.sort(reverse=True) print("%-12s%-10s"%('word','Count')) print('-'*21) for Count,Word in resultwords: if(Count>2): print("%-13s%-3d"%(Word,Count)) Wdict = {} #在这也可以将下面的代码封装到main(),然后执行main()运行程序 FileODJ = open('wordtest.txt','rU') for line in FileODJ: collect(line,Wdict) Printf(Wdict)