依赖编译器优化是脆弱的。被接受的答案中的基准和安托万-特兰给出的数字是不可信的。Andrew Hare 犯了一个错误,在他的方法中包含了对 repr的调用。这同样减慢了所有方法的速度,但模糊了构造字符串的真正代价。
使用 join。它非常快,而且更加健壮。
$ ipython3
Python 3.5.1 (default, Mar 2 2016, 03:38:02)
IPython 4.1.2 -- An enhanced Interactive Python.
In [1]: values = [str(num) for num in range(int(1e3))]
In [2]: %%timeit
...: ''.join(values)
...:
100000 loops, best of 3: 7.37 µs per loop
In [3]: %%timeit
...: result = ''
...: for value in values:
...: result += value
...:
10000 loops, best of 3: 82.8 µs per loop
In [4]: import io
In [5]: %%timeit
...: writer = io.StringIO()
...: for value in values:
...: writer.write(value)
...: writer.getvalue()
...:
10000 loops, best of 3: 81.8 µs per loop