python 格式化字符串报错:TypeError: not all arguments converted during string formatting

    python 格式化字符串报错:TypeError: not all arguments converted during string formatting

最近在将数据写入数据库的时候,sql报错,TypeError: not all arguments converted during string formatting,

字面意思为:所有参数在格式化时未能格式化。首先,我们要明确,格式化字符串是为了将变量按照定义的格式添加到原有字符串从而生成一个新的字符串,也就是说,有这么几个条件,第一,一个变量,第二,原字符串,第三,原字符串加变量生成新的字符串。代码演示:

a=('a','b')
print(type(a))
print('woxiang %s' % a)
#运行结果:
   #print('woxiang %s' % a)
#TypeError: not all arguments converted during string formatting
#首先定义了一个变量a,变量a的格式为
#原字符串‘woxiang’后想添加变量生成一个新的字符串,很显然,元组是有两个元素,
#占位符%s只占了一个位置,另一个元素无处安放了,因此报错。那么,这个问题怎么解决呢?
#显然,有多少个元素,就放几个占位符%s即可,中间以,隔开即可
a=('a','b')
print(type(a))
print('woxiang %s%s' % a):

#运行结果:

woxiang ab
#那,如果是三个或者四个元素的元组呢?很显然,有几个元素,放几个占位符
#也就是n个元素放n个占位符
b=('aa','cc','dd')
print('woxiang %s,%s,%s' %b)
#运行结果:
#woxiang aa,cc,dd

会不会有第二种方法呢?当然有,这种方法是将整个元组作为一个整体格式化,和上面的方法,将每个元素单独取出格式化是不一样的哦,也就是说效果是完全不一样的,切记。

下面依然是代码演示:

a=('a','b',1,'c')
print(type(a))
print('woxiang %s' % (a,))
#运行结果:

#
#woxiang ('a', 'b', 1, 'c')
#切记,变量名用括号包裹,一定要加一个逗号,这样Python解释器才会将元组整体作为一个元素格式化

列表类型第一种方法是无效的,只能使用第二种方法,望牢记!!!!!!!!!!!!!

 

你可能感兴趣的:(Python,字符串,数据库,列表,python)