python字典的比较_python-将字典与其他字典进行比较,并仅选择...

本文探讨了在Python中从一个字典中筛选出另一个字典中存在的键的方法,并通过实际的基准测试比较了几种实现方式的性能差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

您可以使用字典理解.这将创建一个新的字典,但与您的for循环具有相同的复杂性:

d = {k: v for k, v in packaged.items() if k in union}

这是一些现实的基准测试,以及两个稍微更有效的变体:

union = {'a':'gamma','b':'beta','d':'theta', **dict.fromkeys(range(5000, 10000))}

packaged = {'a':'alpha', 'b':'gamma', 'c':'alpha', **dict.fromkeys(range(1, 15000))}

def dct_cmp(union, packaged):

return {k: v for k, v in packaged.items() if k in union}

def dct_cmp_from_key(union, packaged):

return {k: packaged[k] for k in packaged if k in union}

def dct_cmp_from_key_intersect(union, packaged):

return {k: packaged[k] for k in set(packaged) & set(union)}

def loopy(union, packaged):

for k, v in list(packaged.items()):

if k not in union:

del packaged[k]

return packaged

assert dct_cmp(union, packaged.copy()) == loopy(union, packaged.copy())

assert dct_cmp(union, packaged.copy()) == dct_cmp_from_key(union, packaged.copy())

assert dct_cmp(union, packaged.copy()) == dct_cmp_from_key_intersect(union, packaged.copy())

%timeit dct_cmp(union, packaged.copy()) # 1.94 ms

%timeit dct_cmp_from_key(union, packaged.copy()) # 1.8 ms

%timeit dct_cmp_from_key_intersect(union, packaged.copy()) # 1.8 ms

%timeit loopy(union, packaged.copy()) # 2.75 ms

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值