设置字符串格式时,不了解&Quot;IndexError:元组索引超出范围的原因
问题描述
我查看了类似的问题IndexError
,但没有找到对我的情况的解释。有人能解释一下我为什么会收到这个错误吗?
以下代码
mySF2[0]=['000browser', '1', 'Floor', '0.92', '1.74', 'con', 'None']
insertfmt = ' '.join([
"INSERT INTO mySchema.myTable_{}_name (col1, col2, col3, col4, col5, col6)",
"VALUES ({}, {}, NULLIF({},'None')::decimal, NULLIF({},'None')::decimal, {}, NULLIF({},'None')::int)"
])
insertfmt.format(mySF2[0])
出现此错误
IndexError: tuple index out of range
但是,我计算了7个占位符(即大括号{})和7个要输入的项目。那么为什么会出现这种错误呢?
解决方案
str.format()
接受与格式字符串中的空洞数量相对应的可变数量的参数。在您的示例中,您向.format()
传递了一个参数(列表),这会导致错误,因为它需要七个参数。
若要将数组作为单独的参数传递给函数,需要使用*
运算符,如下所示:
insertfmt.format(*mySF2[0])
相关文章