2014-10-17 84 views
0

我的字典是這樣的:計數每唯一鍵唯一值的Python字典

yahoo.com|98.136.48.100 
yahoo.com|98.136.48.105 
yahoo.com|98.136.48.110 
yahoo.com|98.136.48.114 
yahoo.com|98.136.48.66 
yahoo.com|98.136.48.71 
yahoo.com|98.136.48.73 
yahoo.com|98.136.48.75 
yahoo.net|98.136.48.100 
g03.msg.vcs0|98.136.48.105 

中,我有重複鍵和值。我想要的是具有唯一鍵(ips)和唯一值(域)的最終字典。我已經在下面的代碼:

for dirpath, dirs, files in os.walk(path): 
    for filename in fnmatch.filter(files, '*.txt'): 
     with open(os.path.join(dirpath, filename)) as f: 
      for line in f: 
       if line.startswith('.'): 
        ip = line.split('|',1)[1].strip('\n') 
        semi_domain = (line.rsplit('|',1)[0]).split('.',1)[1] 
        d[ip]= semi_domains 
        if ip not in d: 
         key = ip 
         val = [semi_domain] 
         domains_per_ip[key]= val 

但這是行不通的。有人能幫我解決這個問題嗎?

+0

爲什麼你使用'startswith( '')'? – Kasramvd 2014-10-17 10:00:37

+1

你是什麼意思*「重複鍵」*?字典中的鍵已經是唯一的。 – jonrsharpe 2014-10-17 10:03:18

回答

0

使用defaultdict:

from collections import defaultdict 

d = defaultdict(set) 

with open('somefile.txt') as thefile: 
    for line in the_file: 
     if line.strip(): 
      value, key = line.split('|') 
      d[key].add(value) 

for k,v in d.iteritems(): # use d.items() in Python3 
    print('{} - {}'.format(k, len(v))) 
+0

謝謝@Burhan Khalid它解決了我的問題 – Ounk 2014-10-17 11:35:35

0

您可以使用zip功能拖列表中ipsdomains分開,然後用set得到獨特的作品!

>>>f=open('words.txt','r').readlines() 
>>> zip(*[i.split('|') for i in f]) 
[('yahoo.com', 'yahoo.com', 'yahoo.com', 'yahoo.com', 'yahoo.com', 'yahoo.com', 'yahoo.com', 'yahoo.com', 'yahoo.net', 'g03.msg.vcs0'), ('98.136.48.100\n', '98.136.48.105\n', '98.136.48.110\n', '98.136.48.114\n', '98.136.48.66\n', '98.136.48.71\n', '98.136.48.73\n', '98.136.48.75\n', '98.136.48.100\n', '98.136.48.105')] 
>>> [set(dom) for dom in zip(*[i.split('|') for i in f])] 
[set(['yahoo.com', 'g03.msg.vcs0', 'yahoo.net']), set(['98.136.48.71\n', '98.136.48.105\n', '98.136.48.100\n', '98.136.48.105', '98.136.48.114\n', '98.136.48.110\n', '98.136.48.73\n', '98.136.48.66\n', '98.136.48.75\n'])] 

然後用len可以找到唯一對象的數量! 所有在列表理解一行:

>>> [len(i) for i in [set(dom) for dom in zip(*[i.split('|') for i in f])]] 
[3, 9]