请教一个 Python 处理数据的问题

2017-08-24 15:32:50 +08:00
 NaVient

我现在有两组 list,每组 list 中大概都有 1w 个 dict.结构类似这样的[{},{},{},{},{}]

两组 list 中的 dict 数量是相同的,少部分有差异,不同 list 中的 dict 靠 dict 的 id 来确定匹配 dict.

我想比较下这两组 list 中对应 dict 的 key 对应的 value 值的差异.

目前用两个 for 循环来实现感觉方法很笨,效率实在有点低,应该不是最佳实践.

各位大佬有更好的建议吗?

1583 次点击
所在节点    Python
7 条回复
byluoluo
2017-08-24 15:37:52 +08:00
先对两个 list 排序,然后用一个 for 循环就可以了,时间复杂度就是 O(logN)。不知道有没有理解错你的意思。。
NaVient
2017-08-24 15:43:11 +08:00
@byluoluo 没有理解错,但是我的数据没有排序的参考位,id 是泛指,真实数据是 case_example_xx+1 这样的 T_T
topbandit
2017-08-24 16:00:37 +08:00
1w 个 dict,能把一个 list 中的所有 dict 合并成一个 dict 麽?
NaVient
2017-08-24 16:03:18 +08:00
@topbandit 不能,每个 dict 都是相似的数据结果,可以理解为一次测试的 1w 个结果
forkme
2017-08-24 16:25:52 +08:00
可以先把[{},{},{},{},{}]做个转换,转换为[‘ id1 ’:{},'id2':{},'id2'{},'id4':{},'id5':{},...] , 然后再用一层 for 遍历比较?
forkme
2017-08-24 16:26:33 +08:00
@forkme 错了,是这样{‘ id1 ’:{},'id2':{},'id2'{},'id4':{},'id5':{},...}
NaVient
2017-08-24 16:33:26 +08:00
@forkme 这样挺不错的,时间复杂度没有变得更复杂,我去试试,十分感谢

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/385477

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX