py_08_拓展namedtuple:命令元组

namedtuple:
from collections import namedtuple
步骤:
1. 定义1个类
2.实例化一个元组:这个对象可以看成就是一个元组,元组的操作都适用
3.操作:命令元组也是不可变的有序序列。因此没有增 删 改操作。只有del 删除
4.取值:索引取单个 切片取多个。还可以getattr(实例化元组,字段名) 取值
5.方法有大致5种:
  _make() : 类名调用
  _asdict():获取一个字典对象   实例调用,需要用dict()转化成一个字典
  _fields : 获取元组字段名,得到是一个元组
  _replace(字段名=value):修改字段名的值,返回的是新元组,原来元组不变
  _fields_defaults:
    返回参数defaults的默认值,返回的是一个字典
    3.7版本才行,但是提示是field_defaults 但是我点不出来。
    类名和实例化元组 都可以._fields_defaults

拓展namedtuple()命令元组:

场景处理 (csv excel 数据库)获取的数据

image.png

1. 参数解析:


namedtuple(typename, field_names, *, rename=False, defaults=None, module=None)
'''
typename:类名,命名元组 名字

field_names:字段名
字符串组成的序列
比如 ['x', 'y']、('x', 'y')。

一个长字符串,各个字段名之间用空格或逗号分隔
比如 'x y' 或者 'x, y'
defaults:可以设置默认字

字段名必须符合以下规则:
1.以字母开头
2.由字母、数字、下划线组成
3.不能与关键字重名
4.不能以下划线开头

rename 参数
rename 默认为 False,它是只能以关键字形式指定的参数,或者叫做强制关键字参数 keyword-only argument。
如果 rename=True,那么无效的字段名会被替换为 '_索引值'。
比如 ['abc', 'def', 'ghi', 'abc'] 会被转换成 ['abc', '_1', 'ghi', '_3']。
其中与关键字重名的 'def' 和重复的 'abc' 都被替换成了 '_索引值'。

defaults 参数
defaults 参数默认为 None,是强制关键字参数。
它可以被设置为可迭代对象。
由于默认值参数必须在非默认值参数之后,所以 defaults 参数会被设置给最右边的字段名。
比如字段名为 'x, y, z',defaults 参数为 (1, 2) 时,y 默认为 1,z 默认为 2,x 则没有默认值


'''

2. 命令元组的创建、取值、解包

# 场景处理 (csv excel 数据库)获取的数据
from collections import namedtuple

# 定义一个类:

Love = namedtuple("Love", ["name","gender","age","love_into","hobby"]) # 列表
# Love = namedtuple("Love", ("name","gender","age","love_into","hobby")) # 元组
# Love = namedtuple("Love", "name gender age love_into hobby)  # 字符串 空格间隔
# Love = namedtuple("Love", "name,gender,age,love_into,hobby)  # 字符串 逗号间隔

# 2.创建一个对象:实例化:adeng就当成一个元组
adeng = Love("阿登", "男", 18, "eat apple","数学")
s = ["阿登", "男", 18, "eat apple","数学"]
adeng = Love._make(s)  # 第2种方法创建一个实例

# 3.命令元组取值有也可以通过索引取值,还可以通过字段名取值.方法
print(adeng[1]) # 索引取值 # 男
print(adeng[3:]) # 切片取值  # ('eat apple', '数学')
print(adeng.hobby) # 实例.属性名  # 数学

# 4. 打印元组
print(adeng)  # Love(name='阿登', gender='男', age=18, love_into='eat apple', hobby='数学')
print(adeng.__doc__) # Love(name, gender, age, love_into, hobby)
print(repr(adeng))   # Love(name='阿登', gender='男', age=18, love_into='eat apple', hobby='数学')

# 5.元组解包: adeng就是个元组
a, b, *c = adeng

print(a,b,c) # 阿登 男 [18, 'eat apple', '数学']

3.命令元组的方法:

from collections import namedtuple

# 定义一个类
Love = namedtuple("Love", ("name","gender","age","love_into","hobby"))

# 1. _make()方法创建一个实例:adeng 用类去调_make()
s = ("阿登", "男", 18, "eat apple","数学")
adeng = Love._make(s)

# 字典解包创建一个元组
dict_info = {"name":'阿登', "gender":'男', "age":18, "love_into":'eat apple', "hobby":'数学'}
adeng = Love(**dict_info) # 实际是这样的形式:Love(name='阿登', gender='男', age=18, love_into='eat apple', hobby='数学')

# getattr(adeng,字段名) 获取字段名值
a = getattr(adeng, "name")
print(a) # 阿登
print(getattr(adeng,"age")) # 18

# _asdict() 方法 获取字典对象

print(adeng._asdict()) # OrderedDict([('name', '阿登'), ('gender', '男'), ('age', 18), ('love_into', 'eat apple'), ('hobby', '数学')])
dict_adeng = dict(adeng._asdict())
print(dict_adeng) # {'name': '阿登', 'gender': '男', 'age': 18, 'love_into': 'eat apple', 'hobby': '数学'}

# _fields 获取所有字段名,是一个元组()
print(adeng._fields,type(adeng._fields)) # ('name', 'gender', 'age', 'love_into', 'hobby') <class 'tuple'>
tuple_fields = adeng._fields

# _replace
print(adeng._replace(age= 20)) # Love(name='阿登', gender='男', age=20, love_into='eat apple', hobby='数学')
print(adeng) #  Love(name='阿登', gender='男', age=18, love_into='eat apple', hobby='数学')
adeng.age = 20 # AttributeError: can't set attribute 修改值会报错
# 从上面2个值可以看出replace修改了age=20,原来的元组并没有改变。
# 而是返回一个新的元组 新元组哦

# _fields_defaults


Love = namedtuple("Love", ("name","gender","age","love_into","hobby"),defaults= (18, "eat apple","数学"))
s = ("阿登", "男", 18, "eat apple","数学")
adeng = Love(*s)
print("-----".center(120,"*"))
print(Love._fields_defaults,type(Love._fields_defaults))
# {'age': 18, 'love_into': 'eat apple', 'hobby': '数学'} <class 'dict'>
print(adeng._fields_defaults) # 这里有个坑 点出来是_field_defaults
image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352