如何从字符串列表中创建逗号分隔的字符串?

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

我通常会使用''.join(map(lambda x: x+',',l))[:-1]之类的东西,但也会感到有些不满意。

800123 次浏览
my_list = ['a', 'b', 'c', 'd']
my_string = ','.join(my_list)
'a,b,c,d'

如果列表包含整数,这将不起作用


如果列表包含非字符串类型(如整数、浮点数、bool、None),则执行以下操作:

my_string = ','.join(map(str, my_list))

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

显然,如果你需要在值中引用/转义逗号等,它会变得更复杂。在这种情况下,我建议查看标准库中的csv模块:

https://docs.python.org/library/csv.html

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

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

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

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

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

@jmanning2k使用列表推导的缺点是创建一个新的临时列表。更好的解决方案是使用itertools。Imap返回一个迭代器

from itertools import imap
l = [1, "foo", 4 ,"bar"]
",".join(imap(str, l))

@Peter霍夫曼

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

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


print str(l)[1:-1]


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

下面是Python 3.0中允许非字符串列表项的替代解决方案:

>>> alist = ['a', 1, (2, 'b')]
  • 标准方式

    >>> ", ".join(map(str, alist))
    "a, 1, (2, 'b')"
    
  • the alternative solution

    >>> import io
    >>> s = io.StringIO()
    >>> print(*alist, file=s, sep=', ', end='')
    >>> s.getvalue()
    "a, 1, (2, 'b')"
    

NOTE: The space after comma is intentional.

",".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'

下面是一个带有列表的例子

>>> myList = [['Apple'],['Orange']]
>>> myList = ','.join(map(str, [i[0] for i in myList]))
>>> print "Output:", myList
Output: Apple,Orange

更准确:

>>> myList = [['Apple'],['Orange']]
>>> myList = ','.join(map(str, [type(i) == list and i[0] for i in myList]))
>>> print "Output:", myList
Output: Apple,Orange

示例2:

myList = ['Apple','Orange']
myList = ','.join(map(str, myList))
print "Output:", myList
Output: Apple,Orange
>>> 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(谢谢)。

我想说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([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)

mmm还需要SQL是:

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

enjoit