从一个序列中连接字符串,使每两个连续的对之间添加一个逗号,您的首选方法是什么?也就是说,你如何映射,例如,['a', 'b', 'c']到'a,b,c'?(case ['s']和[]应该分别映射为's'和''。)

我通常会用“。”Join (map(lambda x: x+',',l))[:-1],但也感到有些不满意。


当前回答

mmm还需要SQL是:

l = ["foo" , "baar" , 6]
where_clause = "..... IN ("+(','.join([ f"'{x}'" for x in l]))+")"
>> "..... IN ('foo','baar','6')"

恩乔伊特

其他回答

@Peter霍夫曼

使用生成器表达式也有产生迭代器的好处,但节省了导入itertools。此外,列表推导式通常优先于映射,因此,我希望生成器表达式优先于imap。

>>> l = [1, "foo", 4 ,"bar"]
>>> ",".join(str(bit) for bit in l)
'1,foo,4,bar' 

为什么是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)

",".join(l)并不适用于所有情况。我建议使用StringIO的csv模块

import StringIO
import csv

l = ['list','of','["""crazy"quotes"and\'',123,'other things']

line = StringIO.StringIO()
writer = csv.writer(line)
writer.writerow(l)
csvcontent = line.getvalue()
# 'list,of,"[""""""crazy""quotes""and\'",123,other things\r\n'

除非我遗漏了什么,','.join(foo)应该做你所要求的。

>>> ','.join([''])
''
>>> ','.join(['s'])
's'
>>> ','.join(['a','b','c'])
'a,b,c'

(编辑:正如jmanning2k指出的那样,

','.join([str(x) for x in foo])

更安全,而且相当python化,尽管如果元素可以包含逗号,则结果字符串将难以解析——在这一点上,您需要csv模块的全部功能,Douglas在他的回答中指出。)

l=['a', 1, 'b', 2]

print str(l)[1:-1]

Output: "'a', 1, 'b', 2"