数据类型-元组

  • Post author:
  • Post category:其他




数据类型详解-元组

元组和列表一样都是一组有序的数据的组合。

元组中的元素一但定义不可以修改,因此元组称为 不可变数据类型



元组定义

  • 定义空元组 变量 = (),或者 变量=tuple()
  • 还可以使用 变量 = (1,2,3) 定义含有数据的元组
  • 注意:如果元组中只有一个元素时,必须加逗号 变量=(1,)
  • 特例:变量=1,2,3 这种方式也可以定义为一个元组



元组的相关操作

由于元组是不可变的数据类型,因次只能使用索引进行访问,不能进行其它操作

元组可以和列表一样使用切片方式获取元素



元组的切片操作

元组的切片操作 和列表是一样的

vart = (1,2,3,4,5,5,4,3,2,1)
res = vart[:]  # 获取全部
res = vart[::] # 获取全部
res = vart[1:] # 从索引1开始获取到最后
res = vart[1:3] # 从索引1开始到索引3之前
res = vart[:3]   # 从索引 0 开始 到 索引 3之前
res = vart[1:5:2] # 从索引1开始到索引5之前,步进值为2
res = vart[::2]  # 从索引 0 开始 到 最后 ,步进值为2
res = vart[5:1:-1] # 从索引5开始 到索引 1,步进值为-1  倒着输出



元组推导式 生成器

列表推导式结果返回了一个列表,元组推导式返回的是生成器

语法:
    列表推导式 ==> [变量运算 for i in 容器]  ==> 结果 是一个 列表
    元组推导式 ==> (变量运算 for i in 容器)  ==> 结果 是一个 生成器



生成器是什么?

生成器是一个特殊的迭代器,生成器可以自定义,也可以使用元组推导式去定义

生成器是按照某种算法去推算下一个数据或结果,只需要往内存中存储一个生成器,节约内存消耗,提升性能



语法:

  1. 里面是推导式,外面是一个() 的结果就是一个生成器

  2. 自定义生成器,含有yield关键字的函数就是生成器

含有yield关键字的函数,返回的结果是一个迭代器,换句话说,生成器函数就是一个返回迭代器的函数



如何使用操作生成器?

​ 生成器是迭代器的一种,因此可以使用迭代器的操作方法来操作生成器

示例代码:

# 列表推导式
varlist = [1,2,3,4,5,6,7,8,9]
# newlist = [i**2 for i in varlist]
# print(newlist) # [1, 4, 9, 16, 25, 36, 49, 64, 81]

# 元组推导式 生成器 generator
newt = (i**2 for i in varlist)
print(newt) # <generator object <genexpr> at 0x1104cd4d0>

# 使用next函数去调用
# print(next(newt))
# print(next(newt))

# 使用list或tuple函数进行操作
# print(list(newt))
# print(tuple(newt))

# 使用 for 进行遍历
# for i  in newt:
#     print(i)



yield 关键字

yield关键字使用在生成器函数中

  • yield 和函数中的 return 有点像
  • 共同点:执行到这个关键字后会把结果返回
  • 不同点:
  • return 会把结果返回,并结束当前函数的调用
  • yield 会返回结果,并记住当前代码执行的位置,下一次调用时会从上一次离开的位置继续向下执行
# 使用 yield定义一个 生成器函数
def hello():
    print('hello 1')
    yield 1
    print('world 2')
    yield 2
    print('haha 3')
    yield 3

# 使用生成器返回的迭代器
# r = next(res)
# print(r)
# r = next(res)
# print(r)

# 使用生成器返回的迭代器
# 适应list类似的函数 去调用生成器返回的迭代器时,会把迭代器的返回结果,作为容器的元素
# r = list(res)
# print(r)

# 使用生成器返回的迭代器
# for i in res:
#     print(i)



上面的生成器函数调用时的过程

首先 调用来生成器函数,返回来一个迭代器

  • 第一次去调用迭代器:

    走到当前的生成器函数中,遇到了 yield 1,把1返回,并且记住来当前的执行状态(位置),暂停了执行,等待下一次的调用
  • 第二层去调用迭代器

    从上一次遇到的yield位置开始执行,遇到了 yield 2 ,把2返回,并记住状态,暂停执行,等待下一次调用
  • 第三次去调用迭代器

    从上一次遇到的yield位置开始执行,遇到 yield 3 , 把3返回,并记住了状态,暂停执行,等待下一次调用
  • 如果在最后又调用了迭代器,那么会从上一次的 yield位置开始,结果后面没有了,直接就超出范围,报错
# 使用 生成器函数 改写 斐波那契数列
def fibo():
    a,b,i = 0,1,0
    while True:
        yield b
        a,b = b,a+b
        i+=1

num = int(input('请输入一个正整数:'))
res = fibo()
for i in range(num+1):
    print(next(res),end=",")



版权声明:本文为qq_63892156原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。