失恋的仙人掌 · Flink程序中Tuple类型使用+ ...· 2 周前 · |
谦和的乌冬面 · java Tuple ...· 2 周前 · |
曾深爱过的电池 · 列表、元组、字典和集合 - 雨点的名字 - 博客园· 1 周前 · |
被表白的日记本 · python获取json的所有“键“_pyt ...· 1 周前 · |
沉着的大白菜 · 034 JAVA-Oracle ...· 1 年前 · |
飞奔的铁板烧 · 命令行参数的解析:Flag ...· 1 年前 · |
潇洒的火锅 · Java 中几种获取文件路径的方式_File· 1 年前 · |
骑白马的山羊 · vue小数转百分比显示-掘金· 1 年前 · |
创建空元组
tup1 = ()元组中只包含一个元素时,需要在元素后面添加逗号 , ,否则括号会被当作运算符使用:
元组与字符串类似,下标索引从 0 开始,可以进行截取,组合等。
元组可以使用下标索引来访问元组中的值,如下实例:
以上实例输出结果:
tup1[0]: Google tup2[1:5]: (2, 3, 4, 5)元组中的元素值是不允许修改的,但我们可以对元组进行连接组合,如下实例:
以上实例输出结果:
(12, 34.56, 'abc', 'xyz')元组中的元素值是不允许删除的,但我们可以使用del语句来删除整个元组,如下实例:
以上实例元组被删除后,输出变量会有异常信息,输出如下所示:
删除后的元组 tup : Traceback (most recent call last): File "test.py", line 8, in <module> print (tup) NameError: name 'tup' is not defined与字符串一样,元组之间可以使用 + 、 += 和 * 号进行运算。这就意味着他们可以组合和复制,运算后会生成一个新的元组。
Python 表达式结果 描述len((1, 2, 3))3计算元素个数 >>> a = (1, 2, 3) >>> b = (4, 5, 6) >>> c = a+b (1, 2, 3, 4, 5, 6) (1, 2, 3, 4, 5, 6)连接,c 就是一个新的元组,它包含了 a 和 b 中的所有元素。 >>> a = (1, 2, 3) >>> b = (4, 5, 6) >>> a += b (1, 2, 3, 4, 5, 6) (1, 2, 3, 4, 5, 6)连接,a 就变成了一个新的元组,它包含了 a 和 b 中的所有元素。
('Hi!',) * 4('Hi!', 'Hi!', 'Hi!', 'Hi!')复制
3 in (1, 2, 3)True元素是否存在 for x in (1, 2, 3): print (x, end=" ")1 2 3迭代
因为元组也是一个序列,所以我们可以访问元组中的指定位置的元素,也可以截取索引中的一段元素,如下所示:
tup = ('Google', 'Runoob', 'Taobao', 'Wiki', 'Weibo','Weixin') tup[-2]'Weibo'反向读取,读取倒数第二个元素 tup[1:]('Runoob', 'Taobao', 'Wiki', 'Weibo', 'Weixin')截取元素,从第二个开始后的所有元素。 tup[1:4]('Runoob', 'Taobao', 'Wiki')截取元素,从第二个开始到第四个元素(索引为 3)。运行实例如下:
>>> tup = ( 'Google' , 'Runoob' , 'Taobao' , 'Wiki' , 'Weibo' , 'Weixin' )
tuple和list非常类似,但是tuple一旦初始化就不能修改,比如同样是列出同学的名字:
代码如下:
>>> classmates = ('Michael', 'Bob', 'Tracy')
现在,classmates这个tuple不能变了,它也没有append(),insert()这样的方法。其他获取元素的方法和list是一样的,你可以正常地使用classmates[0],classmates[-1],但不能赋值成另外的元素。不可变的tuple有什么意义?因为tuple不可变,所以代码更安全。如果可能,能用tuple代替list就尽量用tuple。tuple的陷阱:当你定义一个tuple时,在定义的时候,tuple的元素就必须被确定下来,比如:
代码如下:
>>> t = (1, 2) (1, 2)
如果要定义一个空的tuple,可以写成():
代码如下:
>>> t = ()但是,要定义一个只有1个元素的tuple,如果你这么定义:
代码如下:
>>> t = (1)定义的不是tuple,是1这个数!这是因为括号()既可以表示tuple,又可以表示数学公式中的小括号,这就产生了歧义,因此,Python规定,这种情况下,按小括号进行计算,计算结果自然是1。
所以,只有1个元素的tuple定义时必须加一个逗号 ,来消除歧义:
代码如下:
>>> t = (1,)Python在显示只有1个元素的tuple时,也会加一个逗号,,以免你误解成数学计算意义上的括号。
在来看一个"可变的"tuple:
代码如下:
>>> t = ('a', 'b', ['A', 'B']) >>> t[2][0] = 'X' >>> t[2][1] = 'Y' ('a', 'b', ['X', 'Y'])这个tuple定义的时候有3个元素,分别是'a','b'和一个list。不是说tuple一旦定义后就不可变了吗?怎么后来又变了?
别急,我们先看看定义的时候tuple包含的3个元素:当我们把list的元素'A'和'B'修改为'X'和'Y'后,tuple变为:表面上看,tuple的元素确实变了,但其实变的不是tuple的元素,而是list的元素。tuple一开始指向的list并没有改成别的list,所以,tuple所谓的"不变"是说,tuple的每个元素,指向永远不变。即指向'a',就不能改成指向'b',指向一个list,就不能改成指向其他对象,但指向的这个list本身是可变的!理解了"指向不变"后,要创建一个内容也不变的tuple怎么做?那就必须保证tuple的每一个元素本身也不能变。
run
hdr***11@gmail.com
mqslllduoduo
494***660@qq.com
Python元组的升级版本 -- namedtuple(具名元组)
因为元组的局限性:不能为元组内部的数据进行命名,所以往往我们并不知道一个元组所要表达的意义,所以在这里引入了 collections.namedtuple 这个工厂函数,来构造一个带字段名的元组。具名元组的实例和普通元组消耗的内存一样多,因为字段名都被存在对应的类里面。这个类跟普通的对象实例比起来也要小一些,因为 Python 不会用 __dict__ 来存放这些实例的属性。
namedtuple 对象的定义如以下格式:
collections.namedtuple(typename, field_names, verbose=False, rename=False)
返回一个具名元组子类 typename,其中参数的意义如下:
typename :元组名称下面来看看声明一个具名元组及其实例化的方法:
import collections # 两种方法来给 namedtuple 定义方法名 #User = collections.namedtuple('User', ['name', 'age', 'id']) User = collections.namedtuple('User', 'name age id') user = User('tester', '22', '464643123') print(user)
collections.namedtuple('User', 'name age id') 创建一个具名元组,需要两个参数,一个是类名,另一个是类的各个字段名。后者可以是有多个字符串组成的可迭代对象,或者是有空格分隔开的字段名组成的字符串(比如本示例)。具名元组可以通过字段名或者位置来获取一个字段的信息。
输出结果:
User(name='tester', age='22', id='464643123')
具名元组的特有属性:
类属性 _fields :包含这个类所有字段名的元组 类方法 _make(iterable) :接受一个可迭代对象来生产这个类的实例 实例方法 _asdict() :把具名元组以 collections.OrdereDict 的形式返回,可以利用它来把元组里的信息友好的展示出来 from collections import namedtuple # 定义一个namedtuple类型User,并包含name,sex和age属性。 User = namedtuple('User', ['name', 'sex', 'age']) # 创建一个User对象 user = User(name='Runoob', sex='male', age=12) # 获取所有字段名 print( user._fields ) # 也可以通过一个list来创建一个User对象,这里注意需要使用"_make"方法 user = User._make(['Runoob', 'male', 12]) print( user ) # User(name='user1', sex='male', age=12) # 获取用户的属性 print( user.name ) print( user.sex ) print( user.age ) # 修改对象属性,注意要使用"_replace"方法 user = user._replace(age=22) print( user ) # User(name='user1', sex='male', age=21) # 将User对象转换成字典,注意要使用"_asdict" print( user._asdict() ) # OrderedDict([('name', 'Runoob'), ('sex', 'male'), ('age', 22)])以上实例输出结果为:
('name', 'sex', 'age') User(name='Runoob', sex='male', age=12) Runoob User(name='Runoob', sex='male', age=22) OrderedDict([('name', 'Runoob'), ('sex', 'male'), ('age', 22)])
章鱼二哥
490***6@qq.com
tt
308***149@qq.com
邪王真眼喵
112***1525@qq.com
嘻嘻
107***3848@qq.com
kwaaiikweis
335***7519@qq.com
追~
140***7803@qq.com
Code
nyu***@163.com
於黾
252***70@qq.com
曾深爱过的电池 · 列表、元组、字典和集合 - 雨点的名字 - 博客园 1 周前 |
潇洒的火锅 · Java 中几种获取文件路径的方式_File 1 年前 |
骑白马的山羊 · vue小数转百分比显示-掘金 1 年前 |