无法使用 pymysql 将数据文件加载到 MySQL - 找不到文件
Posted
技术标签:
【中文标题】无法使用 pymysql 将数据文件加载到 MySQL - 找不到文件【英文标题】:Unable to load data file into MySQL using pymysql - Can't find file 【发布时间】:2021-03-27 09:02:04 【问题描述】:我正在尝试将分隔文件加载到我的 MariaDB 数据库中,但我不断收到以下错误:
pymysql.err.OperationalError: (1017, "找不到文件'b'/tmp/altered.txt''")
'b' 是从哪里来的?
当我从 MariaDB 提示符运行 LOAD DATA 命令时,它运行良好。
这是我的代码:
print("Prepare to import file")
cnopts=pysftp.CnOpts()
cnopts.hostkeys = None
with pysftp.Connection("8.8.8.8", username="osuser", password="ospassword", cnopts=cnopts) as sftp:
with sftp.cd("/tmp"):
sftp.put("C:/mydirectory/altered.txt")
db = pymysql.connect("8.8.8.8", "dbuser", "dbpassword", "database", local_infile=True)
cursor = db.cursor()
print("importing file")
cursor.execute('LOAD DATA LOCAL INFILE "/tmp/altered.txt" INTO TABLE daily FIELDS TERMINATED BY "|" LINES STARTING BY "148521" TERMINATED BY "\n" ')
db.commit()
cursor.close()
【问题讨论】:
【参考方案1】:LOAD DATA LOCAL INFILE 用于客户端(远程)机器上的文件。
通过使用 LOAD DATA LOCAL INFILE,无需 sFTP 文件。
print("Prepare to import file")
db = pymysql.connect("serverIP", "user", "password", "database", local_infile=True)
cursor = db.cursor()
print("importing file")
load_sql = "LOAD DATA LOCAL INFILE 'C:/directory/file.txt' INTO TABLE table FIELDS TERMINATED BY '|' LINES STARTING BY '11111' TERMINATED BY '\n';"
print("SQL Statement loaded")
cursor.execute(load_sql)
db.commit()
cursor.close()
【讨论】:
以上是关于无法使用 pymysql 将数据文件加载到 MySQL - 找不到文件的主要内容,如果未能解决你的问题,请参考以下文章
Python 3.5 连接Mysql数据库(pymysql 方式)
如何使用 pandas 和 PyMySQL 将 Excel 数据发送到 MySQL?
如何使用 Python 3.6 将 pymysql 模块安装到 AWS Lambda [重复]