pandas将dataFrame写入mysql数据库

import pandas as pd
from sqlalchemy import create_engine

# pd读取CSV,header=0表示第一行有列名,sep通过逗号区分
datas = pd.read_csv('112.csv', header=0, sep=',', encoding='gbk')

# 修改时间格式,将2020/12/13 10:24的时间转化为2020-12-13 10:24
datas['created_at'] = datas['created_at'].apply(lambda x: x[0:4] + "-" + x[5:7] + "-" + x[8:])
datas['updated_at'] = datas['updated_at'].apply(lambda x: x[0:4] + "-" + x[5:7] + "-" + x[8:])
# conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='123456', database='jt_dev')

# 使用sqlalchemy连接mysql数据库
conn = create_engine('mysql+pymysql://root:123456@localhost:3306/jt_dev', encoding='utf-8')

# 执行to_sql必须用到sqlalchemy的engine,否则会报错无法执行
pd.io.sql.to_sql(datas, "system_risks", conn, schema='jt_dev', if_exists='append', index=False)

to_sql执行错误的坑可查看以下

DatabaseError: Execution failed on sql ‘SELECT name FROM sqlite_master WHERE type=‘table‘ AND name=?_weixin_43425561的博客-CSDN博客

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值