鱼C论坛

 找回密码
 立即注册
查看: 1642|回复: 5

[已解决]python批量插入数据里报错。。

[复制链接]
发表于 2019-9-12 12:16:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
import pymysql

conn = pymysql.connect(
    host = 'localhost',
    user = 'root',
    password = '123123',
    database = 'pysqltest'
)

cursor = conn.cursor()
for each in range(20):
    sql = "insert into test_table (id,name,code) values({},{},{}) ".format(5+(each+1),'张'+str(each+1),36+(each+1))
    cursor.execute(sql)

conn.commit()
cursor.close()
conn.close()

---------------------------------------

Traceback (most recent call last):
  File "D:/pythontest/venv/InsertSQL.py", line 13, in <module>
    cursor.execute(sql)
  File "D:\pythontest\venv\lib\site-packages\pymysql\cursors.py", line 170, in execute
    result = self._query(query)
  File "D:\pythontest\venv\lib\site-packages\pymysql\cursors.py", line 328, in _query
    conn.query(q)
  File "D:\pythontest\venv\lib\site-packages\pymysql\connections.py", line 517, in query
    self._affected_rows = self._read_query_result(unbuffered=unbuffered)
  File "D:\pythontest\venv\lib\site-packages\pymysql\connections.py", line 732, in _read_query_result
    result.read()
  File "D:\pythontest\venv\lib\site-packages\pymysql\connections.py", line 1075, in read
    first_packet = self.connection._read_packet()
  File "D:\pythontest\venv\lib\site-packages\pymysql\connections.py", line 684, in _read_packet
    packet.check_error()
  File "D:\pythontest\venv\lib\site-packages\pymysql\protocol.py", line 220, in check_error
    err.raise_mysql_exception(self._data)
  File "D:\pythontest\venv\lib\site-packages\pymysql\err.py", line 109, in raise_mysql_exception
    raise errorclass(errno, errval)
pymysql.err.InternalError: (1054, "Unknown column '张1' in 'field list'")
最佳答案
2019-9-12 14:14:39
本帖最后由 yuweb 于 2019-9-12 14:16 编辑

'张'+str(x) 和你的变量结合起来相当于 '张1'
str.format()基本语法是通过 {} 和 : 来代替以前的 %
"{} {}".format("hello", "world")  # 设置指定位置
相当于'hello world'

可以试试
format(5+x,"\'张"+str(x)+"\'",x,0,36+x)
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2019-9-12 13:45:33 | 显示全部楼层
本帖最后由 叶小贤 于 2019-9-12 14:06 编辑

发现了一个不一样的地方


当我这么写的时候 插入一条
sql = "insert into test_table (id,name,age,sex,code) values(6,'张1',1,0,37) "
cursor.execute(sql)

变量sql是这样的:
sql = (str) 'insert into test_table (id,name,age,sex,code) values(6,\'张1\',1,0,37) '


---------------------------------------------------------------
当我循环插入的时候
x = 1
for each in range(20):
    sql = "insert into test_table (id,name,age,sex,code) values({},{},{},{},{}) ".format(5+x,'张'+str(x),x,0,36+x)
    cursor.execute(sql)
    x += 1

变量sql是这样的:
sql = (str) 'insert into test_table (id,name,age,sex,code) values(6,'张1',1,0,37) '


name 少了2个反斜杠 这是为什么?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-9-12 14:14:39 | 显示全部楼层    本楼为最佳答案   
本帖最后由 yuweb 于 2019-9-12 14:16 编辑

'张'+str(x) 和你的变量结合起来相当于 '张1'
str.format()基本语法是通过 {} 和 : 来代替以前的 %
"{} {}".format("hello", "world")  # 设置指定位置
相当于'hello world'

可以试试
format(5+x,"\'张"+str(x)+"\'",x,0,36+x)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-9-12 14:23:34 | 显示全部楼层
import pymysql

conn = pymysql.connect(
    host = 'localhost',
    user = 'root',
    password = 'root',
    database = 'pysqltest'
)

cursor = conn.cursor()
for each in range(20):
    sql = "insert into test_table (id,name,age,sex,code) values({},{},{},{},{}) ".format(5+each,"\'张"+str(each)+"\'",each,0,36+each)
    cursor.execute(sql)

conn.commit()
cursor.close()
conn.close()
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-9-12 14:25:09 | 显示全部楼层
yuweb 发表于 2019-9-12 14:23
import pymysql

conn = pymysql.connect(

牛逼啊 这是什么原理啊 区别是什么

"\'张"+str(each)+"\'"
'张'+str(each+1)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-9-12 14:37:51 | 显示全部楼层
叶小贤 发表于 2019-9-12 14:25
牛逼啊 这是什么原理啊 区别是什么

"\'张"+str(each)+"\'"

简单的说
"\'张"+str(each)+"\'" 用print输出是
'张1'        (举例哈)
'张'+str(each+1) 用print输出是
张1
\'代表的是转义字符 这边你可以看下百度的解释https://baike.baidu.com/item/%E8 ... A6/86397?fr=aladdin
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-2-5 18:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表