python 序列解包的多种形式及用法解析

序列解包(Sequence Unpacking)

是Python中非常重要和常用的一个功能,可以使用非常简洁的形式完成复杂的功能,大幅度提高了代码的可读性,减少了程序员的代码输入量。

例如,可以使用序列解包功能对多个变量同时进行赋值。

>>> x, y, z = 1, 2, 3 #多个变量同时赋值
>>> v_tuple = (False, 3.5, 'exp')
>>> (x, y, z) = v_tuple
>>> x, y, z = v_tuple
>>> x, y, z = range(3)#可以对range对象进行序列解包
>>> x, y, z = map(str, range(3)) #使用迭代对象进行序列解包

序列解包也可以用于列表、字典、enumerate对象、filter对象等等,但是对字典使用时,默认是对字典“键”进行操作,如果需要对“键:值”对进行操作,需要使用字典的items()方法说明,如果需要对字典“值”进行操作,则需要使用字典的values()方法明确指定。

下面的代码演示了列表与字典的序列解包操作:

>>> a = [1, 2, 3]
>>> b, c, d = a #列表也支持序列解包的用法
>>> x, y, z = sorted([1, 3, 2])  #sorted()函数返回排序后的列表
>>> s = {'a':1, 'b':2, 'c':3}
>>> b, c, d = s.items()
>>> b
('c', 3)
>>> b, c, d = s #使用字典时不用太多考虑元素的顺序
>>> b
'c'
>>> b, c, d = s.values()
>>> print(b, c, d)
1 3 2

使用序列解包可以很方便地同时遍历多个序列。

>>> keys = ['a', 'b', 'c', 'd']
>>> values = [1, 2, 3, 4]
>>> for k, v in zip(keys, values):
print(k, v)
a 1
b 2
c 3
d 4

下面代码演示了对内置函数enumerate()返回的迭代对象进行遍历时序列解包的用法:

>>> x = ['a', 'b', 'c']
>>> for i, v in enumerate(x):
print('The value on position {0} is {1}'.format(i,v))
The value on position 0 is a
The value on position 1 is b
The value on position 2 is c

下面对字典的操作也使用到了序列解包:

>>> s = {'a':1, 'b':2, 'c':3}
>>> for k, v in s.items():  #字典中每个元素包含“键”和“值”两部分
print(k, v)
a 1
c 3
b 2

另外,序列解包还支持下面的用法:

>>> print(*[1, 2, 3], 4, *(5, 6))
1 2 3 4 5 6
>>> *range(4), 4
(0, 1, 2, 3, 4)
>>> {*range(4), 4, *(5, 6, 7)}
{0, 1, 2, 3, 4, 5, 6, 7}
>>> {'x': 1, **{'y': 2}}
{'y': 2, 'x': 1}

补充:Python的序列封包和序列解包功能---两种赋值方式实例说明

Python提供了序列封包和序列解包功能,可以实现:

1、将多个值赋给一个变量时,Python会自动将多个值封装成元组。这个功能就称为序列封包;

2、允许将序列(元组或者列表等)直接赋值给多个变量,此时序列的各元素被依次赋值给每一个变量,此处要求序列的元素个数和变量个数相等,这个功能就成为序列解包。

例如:

序列封包示例,将1、2、3封装成元组后赋值给nums

>>> nums = 1, 2, 3
>>> print(nums)
(1, 2, 3)
>>> print(nums[1])
2

序列解包,将tuple_temp的各元素依次赋值给a, b, c, d, e

>>> tuple_temp = tuple(range(1, 10, 2))
>>> print(tuple_temp)
(1, 3, 5, 7, 9)
>>> a, b, c, d, e = tuple_temp
>>> print(a, b, c, d, e)
1 3 5 7 9

将序列封包和序列解包同时运用,就可以让赋值运算符支持同时将多个值赋值给多个变量。例如:

>>> a, b, c = 1, 2, 3
>>> print(a, b, c)
1 2 3

此处相当于执行了如下过程:

先进行序列封包,将1、2、3封装到元组abc中

abc = 1, 2, 3

再执行序列解包到变量a、b、c中

a, b, c = abc

序列解包时,可以解出部分变量,剩下的依然使用列表变量保存。为了这样操作,Python允许在左边被赋值的变量之前添加“*”,那么该变量就代表一个列表,可以保存多个集合元素,例如:

>>> a, b, *restnum = range(10)
>>> print(a)
0
>>> print(b)
1
>>> print(restnum)
[2, 3, 4, 5, 6, 7, 8, 9]

>>> *frontnum, lastnum = range(10)
>>> print(frontnum)
[0, 1, 2, 3, 4, 5, 6, 7, 8]
>>> print(lastnum)
9

>>> frontnum, *middlenum, lastnum = range(10)
>>> print(frontnum)
0
>>> print(middlenum)
[1, 2, 3, 4, 5, 6, 7, 8]
>>> print(lastnum)
9

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 对Python3 序列解包详解

    Python 中有很多很实用的语法糖,这些语法糖可以帮助我们简化代码.更易理解等优点,接下里再看一个 Python3 中特别实用的语法序列解包(序列解包是 Python 3.0 之后才有的语法). 那什么是序列解包呢?先看一个例子: >>> a, b, c = 1, 2, 3 >>> a 1 >>> b 2 >>> c 3 >>> 这种方法并不限于列表和元组,而是适用于任意序列类型(甚至包括字符串和字节序列).只要赋

  • 详解Python3序列赋值、序列解包

    上节我们提到解决赋值中等号两边参数不一致的方法可以通过切片,但在Python3中我们可以利用特定的语法更加方便的处理这种情况,如下示例. 当带 * 出现在结尾间时 L = [1, 2, 3, 4, 5] a, *b = L print(a, b) 示例结果: 1 [2, 3, 4, 5] 我们可以看到a匹配了列表中第一个元素值,而b匹配了后面所有的内容,并且为列表.即当我们利用带 * 符号匹配时,就可以解决赋值时等号两边元素数量不相等的情形,那么这种带 * 的处理方式都有哪些详细的使用场景和用法

  • python-序列解包(对可迭代元素的快速取值方法)

    一般情况下 x,y,z = 1,2,3 print("x:",x) print("y:",y) print("z:",z) #运行结果 x: 1 y: 2 z: 3 对元祖序列解包 name = ("qiaobushi","wanglihong","leibushi") x,y,z = name print(name) print("x:",x) print(&quo

  • python 序列解包的多种形式及用法解析

    序列解包(Sequence Unpacking) 是Python中非常重要和常用的一个功能,可以使用非常简洁的形式完成复杂的功能,大幅度提高了代码的可读性,减少了程序员的代码输入量. 例如,可以使用序列解包功能对多个变量同时进行赋值. >>> x, y, z = 1, 2, 3 #多个变量同时赋值 >>> v_tuple = (False, 3.5, 'exp') >>> (x, y, z) = v_tuple >>> x, y, z

  • Python3.8对可迭代解包的改进及用法详解

    Python 3 的可迭代解包 在 PEP 3132 - Extended Iterable Unpacking 里面描述了一种对可迭代对象的解包用法,Python 3 可用: In : a, *b, c = range(5) In : a, c Out: (0, 4) In : b Out: [1, 2, 3] In : *a, = range(5) In : a Out: [0, 1, 2, 3, 4] In : for a, *b in [(1, 2, 3), (4, 5, 6, 7)]:

  • Python模块、包(Package)概念与用法分析

    本文实例讲述了Python模块.包(Package)概念与用法.分享给大家供大家参考,具体如下: Python中"模块"的概念 在开发中,我们会有很多函数,我们可以把这些函数都放到一个文件. 比如function.py中: #定义函数 def show(): print("jack") #定义变量 name = "tom" 在其他地方要使用其中的函数怎么办呢? 第一步:需要先引入 import funtions 第二步:通过文件名.函数名/变量名

  • python matplotlib饼状图参数及用法解析

    这篇文章主要介绍了python matplotlib饼状图参数及用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 在python的matplotlib画图函数中,饼状图的函数为pie pie函数参数解读 plt.pie(x, explode=None, labels=None, colors=None, autopct=None, pctdistance=0.6, shadow=False, labeldistance=1.1, star

  • python模块和包的应用BASE_PATH使用解析

    这篇文章主要介绍了python模块和包的应用BASE_PATH使用解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 python中的模块(module)是管理python应用程序的工具,而包(package)是管理模块的工具.在管理和使用包的时候需要注意,调用注意设置文件的相对路径,以保证程序的可移植性. 下面的小程序主要应用os和sys模块中的一些目录管理方法实现了BASE_PATH的设置. import os import sys BAS

  • python爬虫模块URL管理器模块用法解析

    这篇文章主要介绍了python爬虫模块URL管理器模块用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 URL管理器模块 一般是用来维护爬取的url和未爬取的url已经新添加的url的,如果队列中已经存在了当前爬取的url了就不需要再重复爬取了,另外防止造成一个死循环.举个例子 我爬www.baidu.com 其中我抓取的列表中有music.baidu.om,然后我再继续抓取该页面的所有链接,但是其中含有www.baidu.com,可以想

  • Python第三方包PrettyTable安装及用法解析

    可以让我们将数据用表格的方式展示出来 安装方式 pip install PrettyTable 测试是否安装成功 使用方法与对比增加一条数据 先简单的看下如何使用以及效果 import prettytable table = prettytable.PrettyTable() # 定义表头 table.field_names = ['name','age','sex'] # 增加一行数据,列表里的元素按照顺序对应表头 table.add_row(['Jruing','23','男']) prin

  • Python中的迭代器与生成器高级用法解析

    迭代器 迭代器是依附于迭代协议的对象--基本意味它有一个next方法(method),当调用时,返回序列中的下一个项目.当无项目可返回时,引发(raise)StopIteration异常. 迭代对象允许一次循环.它保留单次迭代的状态(位置),或从另一个角度讲,每次循环序列都需要一个迭代对象.这意味我们可以同时迭代同一个序列不只一次.将迭代逻辑和序列分离使我们有更多的迭代方式. 调用一个容器(container)的__iter__方法创建迭代对象是掌握迭代器最直接的方式.iter函数为我们节约一些

随机推荐