2013-07-18 164 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