Python序列内置类型之元组类型详解
1.元组的概念
Python中的元组与列表类似,都是一个序列,不同的是元组的元素不能修改而已。
2.元组的创建
元组使用小括号,列表使用方括号。
tup = ('cdx', 'red', 'molly')
注意:元组中只包含一个元素时,需要在元素后面添加逗号,否则括号会被当作运算符使用。
tup1 = (50)
print(type(tup1)) # 不加逗号,类型为整型
>>> <class 'int'>
tup1 = (50,)
print(type(tup1)) # 加上逗号,类型为元组
>>> <class 'tuple'>
3.元组操作
1.索引与截取(访问元组)
#索引
tup = (1, 2, 3, 4, 5, 6, 7 ) print(tup[2]) >>> 3
#截取
tup = (1, 2, 3, 4, 5, 6, 7 )
print(tup[1:])
>>>2,3,4,5,6,7
2.增删(元组中的元素值是不允许修改的,只能创建一个新元组然后存储值。我们可以对元组进行连接组合,由于元组中的元素值是不允许删除的,我们只能使用del语句来删除整个元组)
tup1 = (12, 34.56); tup2 = ('abc', 'xyz') #修改元组元素操作是非法的。因为元组不能改变 tup1[0] = 100#报错 #创建一个新的元组 tup3 = tup1 + tup2; print (tup3) >>>(12, 34.56, 'abc', 'xyz')
#删除一个元组
tup = ('cdx','redmolly')
del tup
print (tup)
#会报错
Traceback (most recent call last):
File "test.py", line 8, in <module>
3.元组的运算(与字符串一样,元组之间可以使用 + 号和 * 号进行运算。这就意味着他们可以组合和复制,运算后会生成一个新的元组。)
Python 表达式 | 结果 | 描述 |
---|---|---|
len((1, 2, 3)) | 3 | 计算元素个数 |
(1, 2, 3) + (4, 5, 6) | (1, 2, 3, 4, 5, 6) | 连接 |
('Hi!',) * 4 | ('Hi!', 'Hi!', 'Hi!', 'Hi!') | 复制 |
3 in (1, 2, 3) | True | 元素是否存在 |
for x in (1, 2, 3): print (x,) | 1 2 3 | 迭代 |
4.元组的内置函数
序号 | 方法及描述 | 实例 |
---|---|---|
1 | len(tuple) 计算元组元素个数。 |
>>> tuple1 = ('Google', 'Runoob', 'Taobao')
>>> len(tuple1)
3
>>>
|
2 | max(tuple) 返回元组中元素最大值。 |
>>> tuple2 = ('5', '4', '8')
>>> max(tuple2)
'8'
>>>
|
3 | min(tuple) 返回元组中元素最小值。 |
>>> tuple2 = ('5', '4', '8')
>>> min(tuple2)
'4'
>>>
|
4 | tuple(seq) 将列表转换为元组。 |
>>> list1= ['Google', 'Taobao', 'Runoob', 'Baidu']
>>> tuple1=tuple(list1)
>>> tuple1
('Google', 'Taobao', 'Runoob', 'Baidu')
|
5.元组的一些高级补充
1.tuple元素不可变有一种特殊情况,当元素是可变对象时。对象内部属性是可以修改的。tuple的不可变限制只是在一个纬度上:元素的类型。实现理解,tuple的元素所保存的内容(数值或内存地址)是不允许修改的,但地址映射的对象自身是可以修改的。举个例子你就懂了。
a = (1,[3,2]) a[1][0] = 1 print(a) >>>(1, [1, 2]) a[1].append(3) print(a) >>>(1, [1, 2, 3])
2.namedtuple(具名元组)
1.具名元组:因为元组的局限性:不能为元组内部的数据进行命名,所以往往我们并不知道一个元组所要表达的意义,所以引入了 collections.namedtuple这个工厂函数,来构造一个带字段名的元组。所谓工厂函数就是一个加工方法,把数据放进去,加工好了拿出来就是成品。比如(tuple = (12,"cdx","大三")),创建这样一个元组,里面的数据没有名字的话,不知道是干啥的。
2.使用格式:collections.namedtuple(typename, field_names, verbose=False, rename=False)
import collections #User = collections.namedtuple('User', ['name', 'age', 'id']) user = User('tester', '22', '464643123') print(user) >>>User(name='tester', age='22', id='464643123')
PS(想为元组增加一些值,可以用一些其他办法,大家自己想想哦)
- 还没有人评论,欢迎说说您的想法!