630

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

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

4

15 回答 15

1180
my_list = ['a', 'b', 'c', 'd']
my_string = ','.join(my_list)
'a,b,c,d'

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


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

my_string = ','.join(map(str, my_list)) 
于 2008-09-04T21:06:12.030 回答
85

为什么是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)
于 2008-09-04T21:08:29.420 回答
24

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

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'
于 2016-02-10T15:43:06.703 回答
15

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

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

    >>> ", ".join(map(str, alist))
    "a, 1, (2, 'b')"
    
  • 替代解决方案

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

注意:逗号后面的空格是故意的。

于 2008-10-01T09:23:00.990 回答
14

@彼得霍夫曼

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

>>> l = [1, "foo", 4 ,"bar"]
>>> ",".join(str(bit) for bit in l)
'1,foo,4,bar' 
于 2008-09-05T16:29:25.553 回答
13

你不只是想要:

",".join(l)

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

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

于 2008-09-04T21:09:33.770 回答
10
>>> my_list = ['A', '', '', 'D', 'E',]
>>> ",".join([str(i) for i in my_list if i])
'A,D,E'

my_list可以包含任何类型的变量。这避免了结果'A,,,D,E'

于 2017-05-20T11:31:01.017 回答
6
l=['a', 1, 'b', 2]

print str(l)[1:-1]

Output: "'a', 1, 'b', 2"
于 2008-09-15T18:08:41.643 回答
5

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

from itertools import imap
l = [1, "foo", 4 ,"bar"]
",".join(imap(str, l))
于 2008-09-04T21:57:51.050 回答
3

这是一个带有列表的示例

>>> 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
于 2017-05-15T11:25:37.797 回答
3

如果你想做捷径:):

','.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)
于 2020-06-26T16:53:06.920 回答
1

我想说这个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。

于 2018-06-18T15:08:24.447 回答
0

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

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

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

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

更安全且非常 Pythonic,尽管如果元素可以包含逗号,则生成的字符串将难以解析——此时,您需要csv模块的全部功能,正如 Douglas 在他的回答中指出的那样。)

于 2008-09-04T21:10:25.483 回答
0

mmm 还需要 SQL 是:

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

享受

于 2021-11-26T14:44:54.493 回答
-1

我的两分钱。我喜欢更简单的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'

它是 Pythonic,适用于字符串、数字、None 和空字符串。它很短,满足要求。如果列表不包含数字,我们可以使用这个更简单的变体:

>>> ','.join(ifilter(lambda x: x, l))

此外,此解决方案不会创建新列表,而是使用迭代器,例如 @Peter Hoffmann 指出的(谢谢)。

于 2018-01-07T13:56:43.743 回答