在Python 3中打印空格分隔的元素列表

问题描述 投票:26回答:3

我有一个列表L的元素,说自然数。我想用一个空格作为分隔符将它们打印在一行中。但我不希望在列表的最后一个元素之后(或在第一个元素之前)有空格。

在Python 2中,可以使用以下代码轻松完成此操作。 print声明的实现(神秘地,我必须承认)避免在换行符之前打印额外的空格。

L = [1, 2, 3, 4, 5]
for x in L:
    print x,
print

但是,在Python 3中,使用print函数的(假设)等效代码似乎在最后一个数字后产生一个空格:

L = [1, 2, 3, 4, 5]
for x in L:
    print(x, end=" ")
print()

当然,我的问题很简单。我知道我可以使用字符串连接:

L = [1, 2, 3, 4, 5]
print(" ".join(str(x) for x in L))

这是一个非常好的解决方案,但与Python 2代码相比,我发现它反直觉并且肯定更慢。另外,我知道我可以选择是否打印空间,例如:

L = [1, 2, 3, 4, 5]
for i, x in enumerate(L):
    print(" " if i>0 else "", x, sep="", end="")
print()

但这再次比我在Python 2中所做的更糟糕。

所以,我的问题是,我在Python 3中遗漏了什么?我正在寻找的行为是否受print函数的支持?

python python-3.x pretty-print
3个回答
83
投票

您可以将列表应用为单独的参数:

print(*L)

print()负责将每个元素转换为字符串。您可以像往常一样通过设置sep关键字参数来控制分隔符:

>>> L = [1, 2, 3, 4, 5]
>>> print(*L)
1 2 3 4 5
>>> print(*L, sep=', ')
1, 2, 3, 4, 5
>>> print(*L, sep=' -> ')
1 -> 2 -> 3 -> 4 -> 5

除非您需要连接字符串用于其他内容,否则这是最简单的方法。否则,使用str.join()

joined_string = ' '.join([str(v) for v in L])
print(joined_string)
# do other things with joined_string

请注意,这需要手动转换为L中任何非字符串值的字符串!


2
投票

虽然接受的答案绝对清楚,但我只想检查时间效率。

最好的方法是打印转换为字符串的连接数字串。

print(" ".join(list(map(str,l))))

请注意,我使用map而不是loop。我写了一些代码,用于比较时间的所有4种不同方式:

import time as t

a, b = 10, 210000
l = list(range(10, 21000))
tic = t.time()
for i in l:
    print(i, end=" ")

print()
tac = t.time()
t1 = (tac - tic) * 1000
print(*l)
toe = t.time()
t2 = (toe - tac) * 1000
print(" ".join([str(i) for i in l]))
joe = t.time()
t3 = (joe - toe) * 1000
print(" ".join(list(map(str, l))))
toy = t.time()
t4 = (toy - joe) * 1000
print("Time,t1,t2,t3,t4")

结果:

时间74344.76 71790.83 196.99 153.99

输出对我来说非常令人惊讶。 'loop method'和'join-string method'的时间差异很大。

结论:如果尺寸太大(不超过10 ** 5或更多),请不要使用循环打印列表。


0
投票
list = [1, 2, 3, 4, 5]
for i in list[0:-1]:
    print(i, end=', ')
print(list[-1])

for for循环真的需要更长时间才能运行吗?

我试图制作一些东西,用逗号分隔列表中的所有str值,在最后一个条目之前插入“和”,然后想出:

spam = ['apples', 'bananas', 'tofu', 'cats']
for i in spam[0:-1]:
    print(i, end=', ')
print('and ' + spam[-1])
© www.soinside.com 2019 - 2024. All rights reserved.