1
votes

I have two lists:

alist = ['key1','key2','key3','key3','key4','key4','key5']

blist=  [30001,30002,30003,30003,30004,30004,30005]

I want to merge these lists and add them to a dictionary.

I try dict(zip(alist,blist)) but this gives:

{'key3': 30003, 'key2': 30002, 'key1': 30001, 'key5': 30005, 'key4': 30004}

The desired form of the dictionary is:

{'key1': 30001, 'key2': 30002, 'key3': 30003,'key3':30003, 'key4': 30004, 'key4': 30004, 'key5': 30005}

I want to keep the duplicates in the dictionary as well as not join the values in the same key (... key3': 30003,'key3':30003,... ).Is it possible?

Thanks in advance.

3
You can't do that - styvane
you cannot have same name key in dict - akash karothiya
so, better idea to wok with tuple - e7lT2P
Yes, a dictionary has to have unique, hashable keys, so you'll need to look at non-keyed collections such as lists or tuples. Sets, as you're probably aware, will also remove duplicates. There's another possible solution here - DatHydroGuy
Yes, use list or tuple as mentioned. Try this code: tuple(zip(alist, blist)) or list(zip(alist, blist)). - Sanchit

3 Answers

4
votes

You can not do that as dict objects have unique keys. You should just the use list of tuple:

>>> alist = ['key1','key2','key3','key3','key4','key4','key5']
>>> blist=  [30001,30002,30003,30003,30004,30004,30005]

>>> zip(alist, blist)
[('key1', 30001), ('key2', 30002), ('key3', 30003), ('key3', 30003), ('key4', 30004), ('key4', 30004), ('key5', 30005)]

If you want to access all the values based on the key, you may use collections.defaultdict as:

>>> from collections import defaultdict

>>> my_dict = defaultdict(list)
>>> for k, v in zip(alist, blist):
...     my_dict[k].append(v)
...
>>> my_dict
defaultdict(<type 'list'>, {'key3': [30003, 30003], 'key2': [30002], 'key1': [30001], 'key5': [30005], 'key4': [30004, 30004]})

You can access defaultdict similar to normal dict objects. For example:

>>> my_dict['key3']
[30003, 30003]
3
votes

A dictionary uses UNIQUE keys, so its imposible to have duplicates.

3
votes

As dict must use unique keys only, and if you insert same key twice the last one will be stored - this might be something you can use:

from itertools import groupby

alist = ['key1','key2','key3','key3','key4','key4','key5']
alist = [i for i, j in groupby(alist)]

blist = [30001,30002,30003,30003,30004,30004,30005]
blist = [list(j) for i, j in groupby(blist)]

print dict(zip(alist, blist))
#{'key3': [30003, 30003], 'key2': [30002], 'key1': [30001], 'key5': [30005], 'key4': [30004, 30004]}

If you want to preserve the key order as well you can use OrderedDict:

from collections import OrderedDict
print OrderedDict(zip(alist, blist))