python 学习笔记(二):为元组的每个元素命名,提高程序的可读性
在程序中有些数据为固定格式时,即字段数量确定、字段位置顺序确定不变,我们就可以用元组来储存。使用元组的优势是储存空间很小,访问速度也很快。如下代码对每个学生信息用元组来表示:
1 # ('Jim', 16, 'male', 'jim8726@gmail.com')
2 # ('LiLei', 17, 'male', 'lilei8928@qq.com')
3 # ('Lucy', 16, 'female', 'lucy123@yahoo.com')
4
5 student = ('Jim', 16, 'male', 'jim8726@gmail.com')
6 # name
7 print(student[0])
8 # age
9 if student[1] >= 18:
10 pass
11 # sex
12 if student[2] == 'male':
13 pass
程序中使用了0、1、2的索引值来访问字段,这些数字无法明确地表达该字段所代表的含义,对程序的后期维护和修改是非常不利的。那我们能不能像C语言中一样,用名字来明确表达该字段的含义,如:
1 enum Student{
2 NAME,
3 AGE,
4 SEX,
5 EMAIL
6 }
在python中没有真正意义上的枚举类型,我们可以通过其它方法来实现,具体解决方案有二:
方案一:定义类似于其它语言的枚举类型,也就是定义一系列数值常量
1 student = ('Jim', 16, 'male', 'jim8726@gmail.com') 2 NAME, AGE, SEX, EMAIL = range(4) # 将0,1,2,3分别赋给变量 3 print(student[NAME]) # 访问姓名字段 4 if student[AGE] >= 18: # 访问年龄字段 5 ... 6 if student[SEX] == 'male': # 访问性别字段 7 ... 8 print(student[EMAIL]) # 访问Email字段
方案二:使用标准库中的collections.namedtuple替代内置tuple
1 from collections import namedtuple 2 # namedtuple 相当于类工厂,它的第一个参数是类的名称, 3 # 第二个参数是一个属性列表,相当于元组的字段 4 Student = namedtuple('Student', ['name', 'age', 'sex', 'email']) 5 # 实例化一个类对象 6 st = Student('Jim', 16, 'male', 'jim8928@gmail.com') 7 # 不再通过索引来访问元组的字段,而是通过元组对象的属性来访问各个字段 8 print(st.name) 9 print(st.age) 10 print(st.sex) 11 print(st.email)
上面的 Student 类是内置 tuple 类的子类,对象 st 是它的一个实例,在程序中的开销仅比内置 tuple 稍大一些。