元组存储固定格式的数据,例如学生的信息(名字,年龄,性别,邮箱,...),可以减少存储开销。但是每次访问是都通过索引读取数据,大大的降低了程序的可读性。如下:
student = ('jane', 16, 'male', 'jane1999@gmail.com')
# name
print(student[0]) # jane
# mail
print(student[3]) # jane1999@gmail.com
1.通过定义常量对应相应索引
# 定义常量法
NAME, AGE, SEX, MAIL = range(4)
# name
print(student[0])
print(student[NAME]) # jane
# mail
print(student[3])
print(student[MAIL]) # jane1999@gmail.com
2.使用标准库中collections.namedtuple替代内置的tuple
namedtuple是一个函数,它用来创建一个自定义的tuple对象,并且规定了tuple元素的个数,并可以用属性而不是索引来引用tuple的某个元素。这样一来,我们用namedtuple可以很方便地定义一种数据类型,它具备tuple的不变性,又可以根据属性来引用,使用十分方便。
# namedtuple命名元组,是一个工厂函数
from collections import namedtuple
# student = ('jane', 16, 'male', 'jane1999@gmail.com')
Student = namedtuple('Student', ['name','age','sex','mail'])
s = Student('jane', 16, 'male', 'jane1999@gmail.com')
# name
print(s[0])
print(s.name) # jane
# mail
print(s[3])
print(s.mail) # jane1999@gmail.com
'''
def namedtuple(typename, field_names, verbose=False, rename=False, module=None)
Returns a new subclass of tuple with named fields.
'''