这是str.format上的Python 3错误吗?

时间:2011-12-01 00:06:30

标签: python python-3.x cpython python-3.2

sqlstring = 'INSERT INTO {}'
table = 'Product'
sqlstring.format(table)

不会导致'INSERT INTO产品'但仍然'INSERT INTO {}'为什么会这样?

2 个答案:

答案 0 :(得分:5)

Python 3.2正确地做到了这一点:

$ python3.2
Python 3.2.2 (default, Sep  5 2011, 22:09:30) 
[GCC 4.6.1] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> sqlstring = 'INSERT INTO {}'
>>> table = 'Product'
>>> sqlstring.format(table)
'INSERT INTO Product'
>>> 

您使用的是哪个版本?

其他想法:

字符串是不可变的,不能就地自行修改。也许你想要:

sqlstring = sqlstring.format(table)

如果格式字符串自行修改它们对Python程序员来说非常烦人,因为每个格式字符串只能使用一次。有时我们希望有机会构建一个漂亮的格式字符串,然后使用它数百次 - 如果format()返回结果而不是就地修改格式,这很容易。

答案 1 :(得分:5)

format不会修改字符串(它不能因为字符串是不可变的)。它返回一个新字符串。您需要将调用结果分配格式:

result = sqlstring.format(table)