Use str.join() http://docs.python.org/2/library/stdtypes.html#str.join:
>>> mystring = ' '.join(map(str, (34.2424, -64.2344, 76.3534, 45.2344)))
>>> print mystring
34.2424 -64.2344 76.3534 45.2344
您必须在这里使用 map (它将元组中的所有项目转换为字符串),否则您将得到一个TypeError
.
关于以下问题的一点澄清map() http://docs.python.org/2/library/functions.html#map功能:
map(str, (34.2424, -64.2344, 76.3534, 45.2344)
相当于[str(i) for i in (34.2424, -64.2344, 76.3534, 45.2344)]
.
它比使用列表理解快一点:
$ python -m timeit "map(str, (34.2424, -64.2344, 76.3534, 45.2344))"
1000000 loops, best of 3: 1.93 usec per loop
$ python -m timeit "[str(i) for i in (34.2424, -64.2344, 76.3534, 45.2344)]"
100000 loops, best of 3: 2.02 usec per loop
正如这个答案的评论中所示,str.join()
可以使用生成器而不是列表。通常,这会更快,但在这种情况下,它是slower.
如果我要这样做:
' '.join(itertools.imap(str, (34.2424, -64.2344, 76.3534, 45.2344)))
它会比使用慢map()
。不同之处在于imap()
返回一个生成器,同时map()
返回一个列表(在 python 3 中它返回一个生成器)
如果我要这样做:
''.join(str(i) for i in (34.2424, -64.2344, 76.3534, 45.2344))
它会比用括号括起来要慢list理解,因为解释了原因here https://stackoverflow.com/a/9061024/1240268.
在您(OP)的情况下,这两种选择并不重要,因为性能在这里似乎并不重要。但是,如果您曾经处理过大型浮点/整数元组,那么现在您知道如何使用才能获得最大效率:)。