我通过使用以下命令从sql查询中检索数据
bounds = cursor.fetchone()
我得到一个元组,如:
(34.2424, -64.2344, 76.3534, 45.2344)
我想要一个像 34.2424 -64.2344 76.3534 45.2344
34.2424 -64.2344 76.3534 45.2344
是否存在可以做到这一点的功能?
用途str.join():
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。
TypeError
关于map()功能的一些说明:
map()
map(str, (34.2424, -64.2344, 76.3534, 45.2344)等价于[str(i) for i in (34.2424, -64.2344, 76.3534, 45.2344)]。
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()可以使用生成器而不是列表。通常,这会更快,但是在这种情况下,它会 更慢 。
如果我要这样做:
' '.join(itertools.imap(str, (34.2424, -64.2344, 76.3534, 45.2344)))
这将比使用慢map()。区别在于,imap()返回生成器,而map()返回列表(在python 3中,它返回生成器)
imap()
''.join(str(i) for i in (34.2424, -64.2344, 76.3534, 45.2344))
由于这里说明的原因,这比将 列表 理解放在方括号中要慢。
在您的(OP)情况下,这两种选择都不是很重要,因为在这里性能似乎并不重要。但是,如果您曾经处理过大量的浮点/整数元组,那么现在您知道该如何使用才能获得最大的效率:)。