#先回忆下列表的操作
animals=["cat","dog","rabbit"] #找到list中的某个值(第一种方法)
for animal in animals:
if(animal=="cat"):
print("Cat found")
animals=["cat","dog","rabbit"] #找到list中的某个值(第二种方法)
if "cat" in animals:
print("Cat found")
student=["Tom","Jim","Sue","Ann"] #找到某人所得分数
scores=[70,80,85,75]
indexes=[0,1,2,3]
name="Sue"
score=0
for i in indexes:
if student[i]==name:
score=scores[i]
print(score)
#字典结构
scores={}
# Dictionaries 字典结构 key value (键值一一对应)
scores[
"Jim"
]=
80
scores[
"Sue"
]=
85
scores[
"Ann"
]=
75
print
(scores.keys())
#dict_keys(['Jim', 'Sue', 'Ann']) 字典中的key
print
(scores)
#{'Jim': 80, 'Sue': 85, 'Ann': 75} 输出字典中的键和值
print
(scores[
"Sue"
])
#输出键所对应的的值 结果为 85
students={
"Tom"
:
60
,
"Jim"
:
70
}
#创建字典并初始化键值
students[
"Tom"
]=
65
#更改字典中某个键的值
print
(
'Tom'
in
students)
#判断键是否在字典中
#用字典结构做统计数
pantry=[
"apple"
,
"orange"
,
"grape"
,
"apple"
,
"orange"
,
"apple"
,
"tomato"
,
"patato"
,
"grape"
]
pantry_counts={}
for
item
in
pantry:
#对list进行遍历
if
item
in
pantry_counts:
pantry_counts[item]=pantry_counts[item]+
1
else
:
pantry_counts[item]=
1
print
(pantry_counts)
#输出结构{'apple': 3, 'orange': 2, 'grape': 2, 'tomato': 1, 'patato': 1}
补充:dict和set
和list比较,dict有以下几个特点:
(1)查找和插入的速度极快,不会随着key的增加而变慢;
(2)需要占用大量的内存,内存浪费多。
而list相反:
(1)查找和插入的时间随着元素的增加而增加;
(2)占用空间小,浪费内存很少。
#set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key
#set可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、并集等操作
s1=
set
([
1
,
2
,
3
,
4
,
5
,
6
])
#创建一个set,需要提供一个list作为输入集合
s2=
set
([
2
,
3
,
4
,
9
,
8
])
print
(s1&s2)
#交集结果 {{2, 3, 4}
print
(s1|s2)
#并集结果 {1, 2, 3, 4, 5, 6, 8, 9}
s1.add(
11
)
#add(key)方法可以添加元素到set中,可以重复添加,但不会有效果
s1.remove(
1
)
#通过remove(key)方法可以删除元素