ProgrammingError: nan can not be used with MySQL,怎么处理?

NSERT INTO 解决一切格式数据库入库问题, 但是np.NAN 不行,所以考虑可以将 np.NAN,替换成别的值,比如999,'', 'nan', 'none' 都可以,如果想输入到mysql仍然为 (NULL)显示,则需要先将df 转成列表,将值替换成 none。

以下为一个模拟流程:

python 复制代码
#  创建名为 `students_table` 的表
CREATE TABLE IF NOT EXISTS students1 (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(50) NOT NULL,  # 姓名 字符串
    age VARCHAR(50) ,  # 年龄 字符串 , 
    score INT  # 成绩 整型, 如果非得输入,例如 '我', 'None' ,等字符串就不能使用 to_sql 写入库,要用insert_into
);

import pandas as pd
import numpy as np
import pymysql


# 创建包含 NaN 值的 DataFrame
data = {
    'name': ['张三', '李四', '王五'],
    'age': ['', float('nan'), 'nan'],
    'score': ['', np.NAN,'nan']
}

df = pd.DataFrame(data)
df

# 这里直接将NAN替换成999处理
df = df.replace(np.nan,'999')

conn = pymysql.connect(host="xxx.xxx.xxx.xxx", user="root", password="---------", database="testdb", charset="utf8") 
cursor = conn.cursor()

keys = ','.join(df.columns.to_list())
user_data = df.apply(lambda x: tuple(x), axis=1).values.tolist()

for user in user_data:
    print(user)
    query = f"INSERT INTO students1({keys}) VALUES ({('%s,' * len(keys.split(',')) )[:-1]})"
    cursor.execute(query, user)

# 提交更改
conn.commit()
相关推荐
在未来等你28 分钟前
SQL进阶之旅 Day 21:临时表与内存表应用
sql·mysql·postgresql·database·temporary-table·memory-table·sql-optimization
敖云岚1 小时前
【Redis】分布式锁的介绍与演进之路
数据库·redis·分布式
LUCIAZZZ2 小时前
HikariCP数据库连接池原理解析
java·jvm·数据库·spring·springboot·线程池·连接池
我在北京coding2 小时前
300道GaussDB(WMS)题目及答案。
数据库·gaussdb
小Tomkk2 小时前
阿里云 RDS mysql 5.7 怎么 添加白名单 并链接数据库
数据库·mysql·阿里云
明月醉窗台3 小时前
qt使用笔记二:main.cpp详解
数据库·笔记·qt
沉到海底去吧Go3 小时前
【图片自动识别改名】识别图片中的文字并批量改名的工具,根据文字对图片批量改名,基于QT和腾讯OCR识别的实现方案
数据库·qt·ocr·图片识别自动改名·图片区域识别改名·pdf识别改名
老纪的技术唠嗑局4 小时前
重剑无锋,大巧不工 —— OceanBase 中的 Nest Loop Join 使用技巧分享
数据库·sql
未来之窗软件服务4 小时前
JAVASCRIPT 前端数据库-V6--仙盟数据库架构-—-—仙盟创梦IDE
数据库·数据库架构·仙盟创梦ide·东方仙盟·东方仙盟数据库
寒山李白4 小时前
MySQL复杂SQL(多表联查/子查询)详细讲解
sql·mysql·子查询·多表联查