'''
元组和列表一样都是一组有序的数据的组合
元组中的元素一旦定义不可以修改,因此元组称为 不可变数据类型
'''# 元组的定义# 定义空原则 变量 = () 或者 变量 = tuple()# 还可以使用 变量 = (1,2,3)定义含有数据的元组# 注意:如果元组中只有一个元素时,必须加逗号 变量 = (1,)# 特例:变量 = 1,2,3这种方式也可以定义为一个元组'''
元组的相关操作
由于元组是不可变的数据类型,因此只能使用索引进行访问,不能进行其它操作
元组可以和列表一样使用切片方式获取元素
'''# 注意,在定义元组时,如果只有一个元素,也需要使用 逗号
vartuple =(1,2,3,4)# vartuple = 1,2,3# vartuple = 1,# vartuple = (1,)# 获取元组的长度 len()print(vartuple,len(vartuple))# 元组的切片操作,和列表是一样的
vart =(1,2,3,4,5,6)
res = vart[:]#获取全部
res = vart[::]#获取全部
res = vart[1:]#从索引1开始到最后
res = vart[1:3]#从索引1开始到索引3之前
res = vart[:3]#索引0开始到索引3之前
res = vart[1:6:2]#从索引1开始到索引6之前,步进值为2
res = vart[::2]#从索引0到最后,步进值为2
res = vart[6:1:-1]#从索引6开始到索引1,倒着输出# 获取元素在元组中的个数
res = vart.count(75)# 获取一个元素在元组的索引值
res = vart.index(5)# 从指定下标位置开始查找
res = vart.index(5,1)#从指定的索引区间内查找print(res)# 元组 + *运算 合并元组,组成新的元组
res =(1,2,3)+('a','b','c')
res =(1,2,3)*3# 检测一个元素是否在元组中
res =2in res
print(res)
元组推导式 生成器
# 元组推导式 生成器'''
元组推导式
列表推导式结果返回了一个列表,元组推导式返回的是生成器
语法:列表推导式 ==> [变量运算 for i in 容器] ==> 结果 是一个 列表
元组推导式 ==> (变量运算 for i in 容器) ==> 结果 是一个 生成器
生成器是什么 ?
生成器就是一个特殊的迭代器,生成器可以自定义,也可以使用元组推导式定义
生成器是按照某种算法推算下一个数据或结果,只需要往内存中存储一个生成器,节约内存消耗,提高性能
语法:
1.里面是推导式,外面是一个()的结果是一个生成器
2.自定义生成器,含有yield关键字的函数就是生成器
含有yield关键字函数,返回的结果是一个迭代器,换句话说,生成器函数就是一个返回迭代器的函数
如何使用生成器?
生成器是迭代器的一种,因此可以使用迭代的操作方法来操作生成器
'''# 列表推导式
varlist =[1,2,3,4,5]
newlist =[i**2for i in varlist]# print(newlist) # [1, 4, 9, 16, 25]# 元组推导式 生成器 generator
newl =(i**2for i in varlist)print(newl)# 使用next函数去调用# print(next(newl))# print(next(newl))# 使用list或者tuple函数进行操作# print(list(newl))# print(tuple(newl))# 使用for 进行遍历for i in newl:print(i)
练习题
# 使用生成器函数改写 斐波那契数列# 斐波那契数列# def fibo(num):# a,b,i = 0,1,0# while i < num:# print(b)# a,b = b,a+b# i += 1# fibo(7)# 使用生成器函数改写斐波那契数列deffibo(num):
a,b,i =0,1,0while i < num:yield b
a,b = b,a+b
i +=1# res = fibo(11)# print(res)# print(tuple(res))
num =int(input('请输入一个正整数:'))for i in fibo(num):print(i,end=" , ")