从一个序列中连接字符串,使每两个连续的对之间添加一个逗号,您的首选方法是什么?也就是说,你如何映射,例如,['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)
其他回答
my_list = ['a', 'b', 'c', 'd']
my_string = ','.join(my_list)
'a,b,c,d'
如果列表包含整数,这将不起作用
如果列表包含非字符串类型(如整数、浮点数、bool、None),则执行以下操作:
my_string = ','.join(map(str, my_list))
l=['a', 1, 'b', 2]
print str(l)[1:-1]
Output: "'a', 1, 'b', 2"
下面是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')
注意:逗号后的空格是有意的。
我想说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。
mmm还需要SQL是:
l = ["foo" , "baar" , 6]
where_clause = "..... IN ("+(','.join([ f"'{x}'" for x in l]))+")"
>> "..... IN ('foo','baar','6')"
恩乔伊特