实用:collections中namedtuple,defaultdict,OrderedDict的使用

本文详细介绍了Python collections模块中的三种实用数据结构:namedtuple用于创建轻量级命名元组,defaultdict提供默认值的字典,以及OrderedDict保持插入顺序的字典。通过实例演示了它们的用法和优势。
摘要由CSDN通过智能技术生成

一. namedtuple命名元组

from collections import namedtuple
Student=namedtuple('student','name age')
Tom=Student('tom',20)
Jerry=Student('jerry',18)
print(1,Tom.name)
print(2,Jerry.name)
print(3,type(Jerry))

运行结果:

1 tom
2 jerry
3 <class '__main__.student'>

from collections import namedtuple
Point=namedtuple('p','x,y')
print(0,type(Point))
p1=Point(4,5)
print(1,p1)
print(2,p1.x)
print(3,p1.y)
print(4,p1.x+p1.y)

运行结果:

0 <class 'type'>
1 p(x=4, y=5)
2 4
3 5
4 9

二. defaultdict默认字典
传统:

d1 = {}

for k in "abcde":
    for v in range(5):
        if k not in d1.keys():
            d1[k] = []
        d1[k].append(v)
print(d1)
print(type(d1))

运行结果:

{'d': [0, 1, 2, 3, 4], 'c': [0, 1, 2, 3, 4], 'a': [0, 1, 2, 3, 4], 'b': [0, 1, 2, 3, 4], 'e': [0, 1, 2, 3, 4]}
<class 'dict'>

演化:

from collections import defaultdict
d2 = defaultdict(list)

for k in "mnopq":
    for v in range(3):
        d2[k].append(v)
print(d2)
print(type(d2))

运行结果:

defaultdict(<class 'list'>, {'o': [0, 1, 2], 'p': [0, 1, 2], 'm': [0, 1, 2], 'n': [0, 1, 2], 'q': [0, 1, 2]})
<class 'collections.defaultdict'>

三. OrderedDict有序字典

from collections import OrderedDict
import random

d = {'banana':3,'apple':4,'pear':1,'orange':2}
print(1,d)
keys = list(d.keys())
random.shuffle(keys)
print(2,keys)

od = OrderedDict()
for key in keys:
    od[key] = d[key]
print(3,od)

运行结果:

1 {'orange': 2, 'banana': 3, 'pear': 1, 'apple': 4}
2 ['orange', 'pear', 'banana', 'apple']
3 OrderedDict([('orange', 2), ('pear', 1), ('banana', 3), ('apple', 4)])
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值