一尘不染

如何将元组转换为不带逗号和括号的值字符串

python

我通过使用以下命令从sql查询中检索数据

bounds = cursor.fetchone()

我得到一个元组,如:

(34.2424, -64.2344, 76.3534, 45.2344)

我想要一个像 34.2424 -64.2344 76.3534 45.2344

是否存在可以做到这一点的功能?


阅读 176

收藏
2020-12-20

共1个答案

一尘不染

用途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()功能的一些说明:

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中,它返回生成器)

如果我要这样做:

''.join(str(i) for i in (34.2424, -64.2344, 76.3534, 45.2344))

由于这里说明的原因,这比将 列表
理解放在方括号中要慢。


在您的(OP)情况下,这两种选择都不是很重要,因为在这里性能似乎并不重要。但是,如果您曾经处理过大量的浮点/整数元组,那么现在您知道该如何使用才能获得最大的效率:)。

2020-12-20