假设在python中有一字典如下:
x={‘a':'1,2,3', ‘b':'2,3,4'}
需要合并为:
x={‘c':'1,2,3,4'}
需要做到三件事:
1. 将字符串转化为数值列表
2. 合并两个列表并添加新的键值
3. 去除重复元素
第1步通过常用的函数eval()就可以做到了,第2步需要添加一个键值并添加元素,第3步利用set集合的性质可以达到去重的效果,不过最后需要再将set集合转化为list列表。代码如下:
1
2
3
4
5
|
x = { 'a' : '1,2,3' , 'b' : '2,3,4' }
x[ 'c' ] = list ( set ( eval (x[ 'a' ]) + eval (x[ 'b' ])))
del x[ 'a' ]
del x[ 'b' ]
print x
|
输出结果为:
{'c': [1, 2, 3, 4]}
但是在批量处理中,可能会其中一个键值的元素只有1个,导致编译器会识别为int类型,导致出现错误。
1
2
3
4
5
|
x = { 'a' : '1,2,3' , 'b' : '2' }
x[ 'c' ] = list ( set ( eval (x[ 'a' ]) + eval (x[ 'b' ])))
del x[ 'a' ]
del x[ 'b' ]
print x
|
运行结果为:
1
2
3
4
|
Traceback (most recent call last):
File "test.py" , line 2 , in <module>
x[ 'c' ] = list ( set ( eval (x[ 'a' ]) + eval (x[ 'b' ])))
TypeError: can only concatenate tuple ( not "int" ) to tuple
|
处理方法是,人为地将'b'中的元素复制一份,使编译器不识别为int:
1
2
3
4
5
|
x = { 'a' : '1,2,3' , 'b' : '2' }
x[ 'c' ] = list ( set ( eval (x[ 'a' ]) + eval (x[ 'b' ] + ',' + x[ 'b' ])))
del x[ 'a' ]
del x[ 'b' ]
print x
|
这样就能正常运行。这里利用了set会去去除重复元素的特点,添加了相同的元素。不过,若是'b'中的元素为空,这个方法也会失效。这里需要利用python列表中最后一个元素后面允许跟一个逗号的性质,按如下方法处理即可。
1
2
3
4
5
|
x = { 'a' : '1,2,3' , 'b' :''}
x[ 'c' ] = list ( set ( eval (x[ 'a' ] + ',' + x[ 'b' ])))
del x[ 'a' ]
del x[ 'b' ]
print x
|
运行结果:
{'c': [1, 2, 3]}
最后一种方法也能够处理前两种情况。
以上这篇Python合并字典键值并去除重复元素的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。