元组&字典

本文详细介绍了Python中的for循环遍历、range函数,以及元组和字典的基础知识和操作,包括元组的创建、不可变性,字典的键值对、常用方法如get、update和遍历方式。此外,还提供了四个编程练习,涉及随机分配、查找特定字符串和列表值的处理等实际应用场景。
摘要由CSDN通过智能技术生成

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)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值