dic概述:
使用键-值(key-val)存储,具有极快的查找速度
字典是无序的
key的特性:
1、字典中的key必须唯一
2、key必须是不可变的对象
3、字符串、整数等都是不可变的,可以作为key
4、list是可变的,不能作为key
思考:保存多个学生的姓名与成绩
使用字典,学生姓名为key,学生成绩为val
创建字典
dict1 = {"tom":60, "lilei":70}
#元素的访问
#获取: 字典名【key]
print(dict1["tom"])
#print(dict1["fanfan"])#没有
ret = dict1.get("fanfan")
if ret == None:
print("没有")
else:
print("有")
添加
dict1["hanmeimei"] = 99
#因为一个key对应一个val,多次对一个key的val赋值,其实就是修改值
dict1["lilei"] = 80
print(dict1)
删除
#dict1.pop("tom")
#print(dict1)
遍历
for key in dict1:
print(key, dict1[key])
print(dict1.values())
for value in dict1.values():
print(value)
print(dict1.items())
for k, v in dict1.items():
print(k, v)
for i, v2 in enumerate(dict1):
print(i, v2)
和list比较
1、查找和插入的速度极快,不会随着key-value的增加变慢
2、需要占用大量内存,内存浪费多
list
1、查找和插入的速度随着上数据增加而变慢
2、占用空间小,浪费的内存少
#输入一个单词,统计在文章中出现的次数
w = input("请输入要查询的单词")
d = {}
str = "fanfan is a good man! fanfan is a nice man! fanfan is a handsome man! fanfan is a good man! fanfan is a nice man! sunck is a great man! fanfan is a good man! fanfan is a noble man! fanfan is a cool man!"
l = str.split(" ")
for v in l:
d[v] = l.count(v)
if w in d:
print("%s出现了%d次" % (w,d[w]))
else:
print("%s没在文章中" % (w))