如何为元组中的每个元素命名
简述
当对象数据格式固定时,用元组比列表更节省内存空间,
我们使用索引访问元组元素,但是这种访问方式会降低程序的可读性。
举个栗子
对于学生的信息,我们有固定的数据格式,我们可以用元组表示,
但是在我们使用它的时候并不知道stu1[1],stu[2]具体代表什么信息,
这就大大降低了程序的可读性
stu1 = ("tom", 16, "male") def fun1(stu): if stu1[1]: pass if stu1[2] == 'male': pass fun1(stu1)
那我们怎么提高程序的可读性呢,解决方法如下
定义一系列数值常量或枚举类型
定义一系列数值常量
NAME = 0 AGE = 1 SEX = 2 stu1 = ("tom", 16, "male") def fun1(stu): if stu1[NAME]: pass if stu1[SEX] == 'male': pass fun1(stu1)
分析:但是这种方式比较低效,我们可以采用元组的拆包
NAME, AGE, SEX = range(3) stu1 = ("tom", 16, "male") def fun1(stu): if stu1[NAME]: pass if stu1[SEX] == 'male': pass fun1(stu1)
分析:如果还有一个老师的数据结构,元组的第一项是年龄,第二项是姓名,
如果在程序中有多种数据结构,还使用定义常量的方式,有些常量会冲突,
如果分开对象去定义常量,如STU_NAME, TEA_NAME, STU_AGE, TEA_AGE,这样全局变量太多
一般这种情况我们会使用枚举
枚举
优点:相当于创造了一个名称空间
from enum import IntEnum class StudentEnum(IntEnum): NAME = 0 AGE = 1 SEX = 2 stu1 = ("tom", 16, "male") print(StudentEnum.NAME == 0) #True print(StudentEnum.AGE == 1) #True print(isinstance(StudentEnum.NAME, int)) #True
使用标准库中的collections.namedtuple代替内置tuple
优点:
使用元组可以节省空间
提升程序可读性
from collections import namedtuple Student = namedtuple('Student', ['name', 'age', 'sex']) stu1 = Student("tom", 16, "male") print(isinstance(stu1, tuple)) #True print(stu1.name) #“tom” print(stu1.age) #16
参考资料:python3实用编程技巧进阶