我有这个unicode字符串。
u"[(2102, 'a'), (1882, 'b'), (1304, 'c'), (577, 'd'), (470, 'e')]"
<type 'unicode'>
如何将它转换成两个单独的列表?
发布于 2018-02-09 15:33:47
你展示的是一个列表,但你说你有一个字符串。因此,假设您确实有一个字符串,您可以使用eval()
将其转换为一个列表,然后执行一个zip()
将您的值转换为两个元组(可以很容易地转换为列表):
s = u"[(2102, 'a'), (1882, 'b'), (1304, 'c'), (577, 'd'), (470, 'e')]"
type(s)
#<type 'unicode'>
l1, l2 = zip(*(eval(s)))
print(l1)
#(2102, 1882, 1304, 577, 470)
print(l2)
#('a', 'b', 'c', 'd', 'e')
发布于 2018-02-09 15:30:07
您可以使用两个列表理解:
ex = [(2102, 'a'), (1882, 'b'), (1304, 'c'), (577, 'd'), (470, 'e')]
list1 = [x[0] for x in ex]
list2 = [x[1] for x in ex]
发布于 2018-02-09 15:34:11
你也可以试试
unicode_list =[(2102, 'a'), (1882, 'b'), (1304, 'c'), (577, 'd'), (470, 'e')]
map(list,zip(*unicode_list))
其中zip()可以与*操作符一起用于解压缩列表。
https://stackoverflow.com/questions/48709058
复制相似问题