从一个序列中连接字符串,使每两个连续的对之间添加一个逗号,您的首选方法是什么?也就是说,你如何映射,例如,['a', 'b', 'c']到'a,b,c'?(case ['s']和[]应该分别映射为's'和''。)
我通常会用“。”Join (map(lambda x: x+',',l))[:-1],但也感到有些不满意。
从一个序列中连接字符串,使每两个连续的对之间添加一个逗号,您的首选方法是什么?也就是说,你如何映射,例如,['a', 'b', 'c']到'a,b,c'?(case ['s']和[]应该分别映射为's'和''。)
我通常会用“。”Join (map(lambda x: x+',',l))[:-1],但也感到有些不满意。
当前回答
为什么是map/lambda魔法?这样不行吗?
>>> foo = ['a', 'b', 'c']
>>> print(','.join(foo))
a,b,c
>>> print(','.join([]))
>>> print(','.join(['a']))
a
如果列表中有数字,你可以使用列表推导式:
>>> ','.join([str(x) for x in foo])
或者一个生成器表达式:
>>> ','.join(str(x) for x in foo)
其他回答
下面是Python 3.0中允许非字符串列表项的替代解决方案:
>>> alist = ['a', 1, (2, 'b')]
标准方式 >>> ", "。加入(地图(str,倾斜的)) a, 1, (2, 'b') 替代解决方案 >>>导入IO >>> s = io.StringIO() >>> print(*alist, file=s, sep=', ', end= ") > > > s.getvalue () a, 1, (2, 'b')
注意:逗号后的空格是有意的。
mmm还需要SQL是:
l = ["foo" , "baar" , 6]
where_clause = "..... IN ("+(','.join([ f"'{x}'" for x in l]))+")"
>> "..... IN ('foo','baar','6')"
恩乔伊特
>>> my_list = ['A', '', '', 'D', 'E',]
>>> ",".join([str(i) for i in my_list if i])
'A,D,E'
My_list可以包含任何类型的变量。这样就避免了“A…D,E”的结果。
我的意见。我喜欢python中更简单的一行代码:
>>> from itertools import imap, ifilter
>>> l = ['a', '', 'b', 1, None]
>>> ','.join(imap(str, ifilter(lambda x: x, l)))
a,b,1
>>> m = ['a', '', None]
>>> ','.join(imap(str, ifilter(lambda x: x, m)))
'a'
它是python的,适用于字符串,数字,None和空字符串。它很短,满足要求。如果列表不包含数字,我们可以使用这个更简单的变体:
>>> ','.join(ifilter(lambda x: x, l))
此外,这个解决方案不创建一个新的列表,而是使用一个迭代器,如@Peter Hoffmann pointing(谢谢)。
如果你想做快捷方式:):
','.join([str(word) for word in wordList])
但如果你想用逻辑来炫耀:):
wordList = ['USD', 'EUR', 'JPY', 'NZD', 'CHF', 'CAD']
stringText = ''
for word in wordList:
stringText += word + ','
stringText = stringText[:-2] # get rid of last comma
print(stringText)