从一个序列中连接字符串,使每两个连续的对之间添加一个逗号,您的首选方法是什么?也就是说,你如何映射,例如,['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],但也感到有些不满意。
当前回答
",".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'
其他回答
我想说csv库是这里唯一明智的选择,因为它是用来处理所有csv用例的,比如字符串中的逗号等。
输出列表l到csv文件。
import csv
with open('some.csv', 'w', newline='') as f:
writer = csv.writer(f)
writer.writerow(l) # this will output l as a single row.
也可以使用writer.writerows(iterable)将多行输出到csv。
这个例子与Python 3兼容,因为这里的另一个答案使用的是StringIO,即Python 2。
难道你不想:
",".join(l)
显然,如果你需要在值中引用/转义逗号等,它会变得更复杂。在这种情况下,我建议查看标准库中的csv模块:
https://docs.python.org/library/csv.html
我的意见。我喜欢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(foo)应该做你所要求的。
>>> ','.join([''])
''
>>> ','.join(['s'])
's'
>>> ','.join(['a','b','c'])
'a,b,c'
(编辑:正如jmanning2k指出的那样,
','.join([str(x) for x in foo])
更安全,而且相当python化,尽管如果元素可以包含逗号,则结果字符串将难以解析——在这一点上,您需要csv模块的全部功能,Douglas在他的回答中指出。)
mmm还需要SQL是:
l = ["foo" , "baar" , 6]
where_clause = "..... IN ("+(','.join([ f"'{x}'" for x in l]))+")"
>> "..... IN ('foo','baar','6')"
恩乔伊特