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()
相关推荐
东软吴彦祖23 分钟前
包安装利用 LNMP 实现 phpMyAdmin 的负载均衡并利用Redis实现会话保持nginx
linux·redis·mysql·nginx·缓存·负载均衡
慵懒的猫mi1 小时前
deepin分享-Linux & Windows 双系统时间不一致解决方案
linux·运维·windows·mysql·deepin
小高不明2 小时前
仿 RabbitMQ 的消息队列2(实战项目)
java·数据库·spring boot·spring·rabbitmq·mvc
DZSpace2 小时前
使用 Helm 安装 Redis 集群
数据库·redis·缓存
张飞光2 小时前
MongoDB 创建集合
数据库·mongodb
Hello Dam2 小时前
接口 V2 完善:基于责任链模式、Canal 监听 Binlog 实现数据库、缓存的库存最终一致性
数据库·缓存·canal·binlog·责任链模式·数据一致性
张飞光2 小时前
MongoDB 创建数据库
数据库·mongodb·oracle
摘星怪sec3 小时前
【漏洞复现】|方正畅享全媒体新闻采编系统reportCenter.do/screen.do存在SQL注入
数据库·sql·web安全·媒体·漏洞复现
基哥的奋斗历程3 小时前
学到一些小知识关于Maven 与 logback 与 jpa 日志
java·数据库·maven
苏-言4 小时前
MyBatis最佳实践:提升数据库交互效率的秘密武器
数据库·mybatis