for循环遍历
for循环
- 通过for循环来遍历列表
语法
for 变量 in 序列(遍历的规则):
代码块
- 注意: for循环的代码块会执行多次,序列中有几个元素就会执行几次。每执行一次就会将序列中的一个元素赋值给变量,所以我们可以通过变量来获取列表中的元素
range(start, stop[, step])
参数说明
- ·start: 计数从 start 开始。默认是从 0 开始。例如range(5)等价于range(0, 5);
- stop: 计数到 stop 结束,但不包括 stop。例如:range(0, 5) 是[0, 1, 2, 3, 4]没有5
- step:步长,默认为1。例如:range(0, 5) 等价于 range(0, 5, 1)
元组
元组简介
- 元组表现形式tuple
- 元组是一个不可变序列(一般当我们希望数据不改变时,我们使用元组,其他情况下基本都用列表)
- 使用()创建元素
- 元组不是空元组至少有一个 逗号(,) 当元组不是空元组时括号可以省略
- 元组解包指将元组当中的每一个元素都赋值给一个变量
字典
字典简介
字典的基本介绍
- 字典属于一种新的数据结构称为映射(mapping)
- 字典的作用和列表类似,都是用来存储对象的容器
- 列表存储数据的性能好,但是查询数据的性能差,字典正好与之相反
- 在字典中每一个元素都有唯一的名字,通过这个唯一的名字可以找到指定的元素
- 这个唯一的名字我们称之为key 通过key可以快速查询value 也可以称之为值
- 字典我们也称之为键值对(key-value)结构
- 每个字典中都可以有多个键值对,而每一个键值对我们称其为一项(item)
- 创建一个有数据的字典 语法 {key:value}
- 字典的值可以是任意对象 字典的键可以是任意的不可变对象(int str bool tuple…)
- 字典的键是不能重复的,如果出现重复的后面的会替换前面的
字典的使用
- dict()函数来创建字典
- get(key[,default]) 根据键来获取字典的值。第二个参数可以指定一个默认值,当获取不到值的时候会返回默认值
- update() 将其他字典的key-value添加到当前的字典当中
- del 删除字典中的key-value
- setdefault() 返回指定键的值。如果该键不存在,则插入具有指定值的键。
- popitem() 删除字典最后的一个key-value 这个方法是有返回值的。删除之后它会将删除的key-value作为返回值返回
- pop(key[,default]) 根据key删除自定中的value。第二个参数可以指定一个默认值,当获取不到值的时候会返回默认值
copye()
copy() 方法用来对字典进行潜复制
注意:潜复制只会复制字典本身,如果字典中还有个字典是不会进行复制的
遍历字典
我们主要可以通过3种方式对字典进行遍历
- keys() 该方法返回字典所有的key
- values() 该方法返回一个序列 序列中保存有字典的值
- items() 该方法会返回字典中所有的项 它返回一个序列,序列中包含有双值子序列 双值分别是 字典中的key和value
EXERCISES :
1.现在有8位老师,3个办公室,要求将8位老师随机的分配到三个办公室中。
import random
teacher=['t1','t2','t3','t4','t5','t6','t7','t8']
offices=[[],[],[]]
for i in teacher :
offices[random.randint(0,2) ].append(random.choice(teacher))
print(offices)
2.现在有8位老师,3个办公室,要求将8位老师随机的分配到三个办公室中且没有空的办公室。
import random
teacher=['t1','t2','t3','t4','t5','t6','t7','t8']
offices=[[],[],[]]
i=0
for j in teacher :
if i == 7 and [] in offices :
offices[offices.get([])].append(teacher[7])
else:
offices[random.randint(0,2)].append(random.choice(teacher))
print(offices)
3.a = {“name”:“123”,“data”:{“result”:[{“src”:“python1”},{“src”:“python2”},{“src”:“python3”}]}} 找到python1/python2/python3
a = {"name":"123","data":{"result":[{"src":"python1"},{"src":"python2"},{"src":"python3"}]}}
b=a['data']['result']
for i in b :
c = i['src']
print(c , end=' / ')
4.有如下值列表[11,22,33,44,55,66,77,88,99,90], 将所有大于66的值保存至字典的第一个key的值中,将小于66值保存至第二个key的值中。
a=[11,22,33,44,55,66,77,88,99,90]
dict1 = dict( key1 = [],key2=[])
for i in a :
if i > 66 :
dict1['key1'].append(i)
else :
dict1['key2'].append(i)
print(dict1)