无法使用 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 - 找不到文件的主要内容,如果未能解决你的问题,请参考以下文章

PyMySQL 和 OrderedDict

Python 3.5 连接Mysql数据库(pymysql 方式)

如何使用 pandas 和 PyMySQL 将 Excel 数据发送到 MySQL?

如何使用 Python 3.6 将 pymysql 模块安装到 AWS Lambda [重复]

AWS 无法导入模块“app”:没有名为 Pymysql 的模块

无法将完整数据从 json 文件加载到数据框中