2013-07-18 166 views
0
data1=[{'aa': None, 'bb': 'dffg', 'cc': '0', 'dd': '1234', 'ee': None}, 
{'aa': 'cdfg', 'bb': None, 'cc': '0', 'dd': 'sc12', 'ee': 'edft'}, 
{'aa': 'bvkjdi', 'bb': 'hdjd', 'cc': '0', 'dd': None, 'ee': None}, 
{'aa': None, 'bb': None, 'cc': '0', 'dd': '123dg', 'ee': 'hddk'}] 


data2={'aa': ('','cdfg', 'bvkjdi', ''), 'bb': ('dffg','', 'hdjd', ''), 
'cc': ('0', '0', '0','0'), 'dd': ('1234', 'sc12', '','123dg'), 
'ee': ('', 'edft', '','hddk') } 

data1是列表中的许多字典与其关键值和data2是与其关键值的字典。需要比较这两个,但格式是不同的。需要弄清楚和简单的方法来比较'aa'data1从data2的'aa',data1的'bb'值到data2的'bb'值,类似于其余的东西。请帮我比较一下。比较列表与词典?

+0

你是什么意思,比较?,差异,共享,真/假检查,看看他们是否一样...? – jcr

+0

@azorius:检查它们是否相同 – user2558589

+0

请举例。你不需要显示代码,只需显示你的“字典”和你的“列表”和预期的输出。 –

回答

0

你可以做到以下几点:

>>> data1_like_data2 = {} 
>>> for item in data1: 
...  for key in item: 
...   try: 
...    data1_like_data2[key] += (item[key],) 
...   except: 
...    data1_like_data2.update({key:(item[key],)}) 
>>> data1_like_data2 
{'aa': (None, 'cdfg', 'bvkjdi', None), 'cc': ('0', '0', '0', '0'), 'dd': ('1234', 'sc12', None, '123dg'), 'ee': (None, 'edft', None, 'hddk'), 'bb': ('dffg', None, 'hdjd', None)} 

然后直接对它们进行比较,

>>> data1_like_data2 == data2: 
>>> False 

它给假的,因为没有和 '0' 的问题。根据您的要求进行排序,然后才能正常工作。

+0

:是的,与此相同 – user2558589

+0

@ user2558589这是否解决您的问题呢? – Sudipta

+0

@ Sudipta:我需要比较data1的aa和bb值到data2的aa和bb值,请帮助我 – user2558589

0

假设无='0 = '0' 我想这就是你想要什么:

data1=[{'aa': None, 'bb': 'dffg', 'cc': 0, 'dd': '1234', 'ee': None}, 
{'aa': 'cdfg', 'bb': None, 'cc': 0, 'dd': 'sc12', 'ee': 'edft'}, 
{'aa': 'bvkjdi', 'bb': 'hdjd', 'cc': 0, 'dd': None, 'ee': None}, 
{'aa': None, 'bb': None, 'cc': 0, 'dd': '123dg', 'ee': 'hddk'}] 


data2={'aa': ('','cdfg', 'bvkjdi', ''), 'bb': ('dffg','', 'hdjd', ''), 
'cc': ('0', '0', '0','0'), 'dd': ('1234', 'sc12', '','123dg'), 
'ee': ('', 'edft', '','hddk') } 

results = {} 
for key in data2: 
    set1 = [x[key] for x in data1] 
    set1 = [str(x) if x is not None else '' for x in set1] 
    set2 = list(data2[key]) 

    results[key] = set1 == set2   
# results = {'aa': True, 'cc': True, 'dd': True, 'ee': True, 'bb': True}  
0

可以重组data1看起来像data2使用字典解析:

>>> n = {k: tuple(d[k] for d in data1) for k in data2} 
>>> n 
{'aa': (None, 'cdfg', 'bvkjdi', None), 'cc': ('0', '0', '0', '0'), 
'dd': ('1234', 'sc12', None, '123dg'), 'ee': (None, 'edft', None, 'hddk'), 
'bb': ('dffg', None, 'hdjd', None)} 

既然你想None匹配'',我们可以将其转换为:

>>> n = {k: tuple(d[k] if d[k] is not None else '' for d in data1) for k in data2} 
>>> n 
{'aa': ('', 'cdfg', 'bvkjdi', ''), 'cc': ('0', '0', '0', '0'), 
'dd': ('1234', 'sc12', '', '123dg'), 'ee': ('', 'edft', '', 'hddk'), 
'bb': ('dffg', '', 'hdjd', '')} 

,其后:

>>> n == data2 
True 

如果你只是想比较aabb键/值对,你可以将它们拉出来:

>>> keys_to_compare = {'aa', 'bb'} 
>>> d1 = {k: tuple(d[k] if d[k] is not None else '' for d in data1) for k in keys_to_compare} 
>>> d2 = {k: v for k,v in data2.iteritems() if k in keys_to_compare} 
>>> d1 == d2 
True 

或将其就地比较:

>>> all(tuple(d[k] if d[k] is not None else '' for d in data1) == data2[k] for k in keys_to_compare) 
True 
+0

我需要比较data1的aa和bb值到data2的aa和bb值,请帮助我。 – user2558589

+0

@ user2558589:你不是说“其余的东西同样如此”吗? – DSM

+0

谢谢,它工作正常。 – user2558589