Python读取Excel/CSV到MySQL

【1】Python读取CSV到MySQL

python 复制代码
import pandas as pd
from sqlalchemy import create_engine

# 数据库连接参数(请根据你的实际配置修改)
DB_USER = 'root'      # 如 root
DB_PASSWORD = '123456'  # 如 123456
DB_HOST = 'localhost'          # 或 127.0.0.1
DB_PORT = 3306
DB_NAME = 'travel_pmm'

# 构建数据库连接 URL
engine_url = f"mysql+pymysql://{DB_USER}:{DB_PASSWORD}@{DB_HOST}:{DB_PORT}/{DB_NAME}?charset=utf8mb4"

# 创建 SQLAlchemy 引擎
engine = create_engine(engine_url, echo=False)

# 读取 CSV 文件(假设文件在当前目录下)
df = pd.read_csv('trip_fujian_scenic_detail_20260214_155519.csv', encoding='utf-8')

# 可选:查看前几行确保数据正确
print(df.head())
print(df.dtypes)

# 将数据写入 MySQL 表(表名设为 travel_records)
# if_exists: 'fail'(默认), 'replace'(删旧建新), 'append'(追加)
df.to_sql(
    name='trip_fujian_scenic_detail',
    con=engine,
    if_exists='replace',  # 第一次用 replace,后续可用 append
    index=False,          # 不写入 pandas 的索引
    chunksize=1000        # 分批插入,提高性能
)

【2】Python读取xls到MySQL

python 复制代码
import pandas as pd
from sqlalchemy import create_engine

# === 1. 配置 MySQL 连接信息 ===
DB_USER = 'root'      # 如 root
DB_PASSWORD = '123456'  # 如 123456
DB_HOST = 'localhost'
DB_PORT = 3306
DB_NAME = 'travel_pmm'         # 你的数据库名

# 构建连接 URL(注意:charset=utf8mb4 支持 emoji 和中文)
engine_url = f"mysql+pymysql://{DB_USER}:{DB_PASSWORD}@{DB_HOST}:{DB_PORT}/{DB_NAME}?charset=utf8mb4"

# 创建数据库引擎
engine = create_engine(engine_url, echo=False)  # echo=True 可打印 SQL 日志

# === 2. 读取 Excel 文件 ===
# 假设文件名为 data.xlsx,位于当前目录
file_path = '1994-2024年度旅游数据3.xls'

# 读取第一个 sheet(默认)
df = pd.read_excel(file_path, engine='xlrd')
# df = pd.read_excel(file_path, engine='openpyxl')

# 如果要读取特定 sheet,用:
# df = pd.read_excel(file_path, sheet_name='Sheet1', engine='openpyxl')

# 可选:查看数据
print("✅ 数据前5行:")
print(df.head())
print("\n✅ 数据类型:")
print(df.dtypes)

# === 3. 数据清洗(可选但推荐)===
# 示例:去除列名前后空格
df.columns = df.columns.str.strip()

# 示例:处理 NaN 值(MySQL 不喜欢 NaN)
df = df.where(pd.notnull(df), None)  # 将 NaN 转为 None(对应 SQL 的 NULL)

# === 4. 写入 MySQL ===
table_name = 'travel_money_data'  # 目标表名

df.to_sql(
    name=table_name,
    con=engine,
    if_exists='append',   # 'fail'(默认), 'replace'(删表重建), 'append'(追加)
    index=False,          # 不写入 pandas 的行索引
    chunksize=1000,       # 分批插入,提升性能
    method='multi'        # 使用多值插入,加速
)

print(f"\n✅ 成功将 {len(df)} 行数据写入 MySQL 表 `{DB_NAME}.{table_name}`!")

【3】Python读取xlsx到MySQL

python 复制代码
import pandas as pd
from sqlalchemy import create_engine

# === 1. 配置 MySQL 连接信息 ===
DB_USER = 'root'      # 如 root
DB_PASSWORD = '123456'  # 如 123456
DB_HOST = 'localhost'
DB_PORT = 3306
DB_NAME = 'travel_pmm'         # 你的数据库名

# 构建连接 URL(注意:charset=utf8mb4 支持 emoji 和中文)
engine_url = f"mysql+pymysql://{DB_USER}:{DB_PASSWORD}@{DB_HOST}:{DB_PORT}/{DB_NAME}?charset=utf8mb4"

# 创建数据库引擎
engine = create_engine(engine_url, echo=False)  # echo=True 可打印 SQL 日志

# === 2. 读取 Excel 文件 ===
# 假设文件名为 data.xlsx,位于当前目录
file_path = '1994-2024年度旅游数据3.xls'

# 读取第一个 sheet(默认)
df = pd.read_excel(file_path, engine='openpyxl')

# 如果要读取特定 sheet,用:
# df = pd.read_excel(file_path, sheet_name='Sheet1', engine='openpyxl')

# 可选:查看数据
print("✅ 数据前5行:")
print(df.head())
print("\n✅ 数据类型:")
print(df.dtypes)

# === 3. 数据清洗(可选但推荐)===
# 示例:去除列名前后空格
df.columns = df.columns.str.strip()

# 示例:处理 NaN 值(MySQL 不喜欢 NaN)
df = df.where(pd.notnull(df), None)  # 将 NaN 转为 None(对应 SQL 的 NULL)

# === 4. 写入 MySQL ===
table_name = 'travel_money_data'  # 目标表名

df.to_sql(
    name=table_name,
    con=engine,
    if_exists='append',   # 'fail'(默认), 'replace'(删表重建), 'append'(追加)
    index=False,          # 不写入 pandas 的行索引
    chunksize=1000,       # 分批插入,提升性能
    method='multi'        # 使用多值插入,加速
)

print(f"\n✅ 成功将 {len(df)} 行数据写入 MySQL 表 `{DB_NAME}.{table_name}`!")
相关推荐
AC赳赳老秦1 小时前
边缘AI落地趋势:DeepSeek在工业边缘节点的部署与低功耗优化技巧
人工智能·python·算法·云原生·架构·pygame·deepseek
小鸡吃米…1 小时前
TensorFlow 实现线性回归
人工智能·python·tensorflow·线性回归
一个处女座的程序猿O(∩_∩)O1 小时前
Python面向对象编程中的继承特性详解
开发语言·python
was1722 小时前
多功能、自动化整理文件夹Python脚本
运维·python·自动化
Katecat996632 小时前
【无标题】
python
weixin_440401692 小时前
Coze-智能体Agent(工作流:批处理+图像生成+视频生成+)未完待续
python·ai·agent·coze
码云数智-大飞2 小时前
PyCharm 安装 Python 模块失败?常见 pip 报错原因与解决方案全解析
python·pycharm·pip
wanderful_2 小时前
MySQL当中的修改外键关联主键字段属性
数据库·mysql
0思必得02 小时前
[Web自动化] Selenium获取网页元素在桌面上的位置
前端·python·selenium·自动化