为了账号安全,请及时绑定邮箱和手机立即绑定

如何为元组中每个元素命名,提高程序可读性

案例:
学生信息系统中数据格式固定:
(名字,年龄,性别,邮箱地址)
学生数很多为了减小存储开销,用元组表示学生信息,使用索引index访问元组的信息,降低了程序的可读性。
元组:存储空间小,访问速度快,但用索引查找值不利于程序维护。

student = ('Jim',16,'male','jim8721@gmail.com')

#name
print student[0]

#age
if student[1] >= 18:
    pass

#sex
if student[2] == 'male'
    pass

c语言中,采用宏定义预处理(不是很懂)

// C
#define NAME 0
#define AGE 1

enum Student{
        NAME,
        AGE,
        SEX,
}

解决方案1:定义数值常量,类似其他语言中的枚举类型;列表拆包

NAME,AGE,SEX,EMAIL = xrange(4)

student = ('Jim',16,'male','jim8721@gmail.com')

#name
print student[NAME]

#age
if student[AGE] >= 18:
    pass

#sex
if student[SEX] == 'male':
    pass

解决方案2:使用标准库中collections.nametuple替代内置tuple

a.利用创建子类的方式:

In [3]: from collections import namedtuple

In [4]: Student = namedtuple('Student',['name','age','sex','email'])

In [12]: isinstance(s,tuple)
Out[12]: True

b.位置传参

In [5]: s = Student('Jim',16,'male','jim8721@gmail.com')

In [6]: s
Out[6]: Student(name='Jim', age=16, sex='male', email='jim8721@gmail.com')

c.关键字传参

In [7]: s2 = Student(name='Jim', age=16, sex='male', email='jim8721@gmail.com')

In [8]: s2
Out[8]: Student(name='Jim', age=16, sex='male', email='jim8721@gmail.com')

利用属性访问元组

In [9]: s.name
Out[9]: 'Jim'

In [10]: s.age
Out[10]: 16

In [11]: s.sex
Out[11]: 'male'

小结:利用collections.nametuple的开销仅比普通元组大一些。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消