经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MySQL » 查看文章
python把数据框写入MySQL的方法
来源:jb51  时间:2022/3/7 11:13:18  对本文有异议

背景:

下文利用上海市2016年9月1日公共交通卡刷卡数据

如图:

想做一下上海市通勤数据挖掘,由于源文件有800多兆,用python读取起来很慢很卡,于是想导入数据库MySQL里面处理,以前一般是打开workbench可视化操作导入数据库,这次想换成代码实现,于是琢磨着如何把这个csv文件用python导进去。
一般的,python把数据框写入数据库有两种方法

利用insert into 命令一条一条插入:

采用这种方法,可以爬一条立马向数据库里面插入一条数据,整体衔接好,不怕大量数据一次性塞进数据库导致拥堵;

pd.io.sql.to_sql( )整个数据框以追加的方式整体复制进去

今天主要研究第二种方法

实现代码:

  1. import pandas as pd ?#导入数据分析模块
  2. import pymysql #导入数据库接口模块
  3. from sqlalchemy import create_engine
  4. data=pd.read_csv(r"D:\数据\yikatongchengkeshuakashuju\201608\SPTCC20160901.csv",engine='python',header=None) #读取数据encoding='mbcs',
  5. data.columns=["卡号","日期","时间","站点","交通方式","费用","是否有优惠"] #由于原csv文件没有表头,这里添加表头
  6. #print(data.head()) #测试
  7.  
  8. db=pymysql.connect("localhost","root","123456","metro_sh",charset="utf8") #链接数据库metro_sh
  9. cursor=db.cursor() #获取游标
  10. cursor.execute("drop table if exists metro_sh_20160901") #以重新写入的方式导入数据表
  11. connect=create_engine("mysql+pymysql://root:123456@localhost:3306/metro_sh?charset=utf8")
  12. pd.io.sql.to_sql(data,"metro_sh_20160901",connect,schema="metro_sh",index=False,if_exists="append")

结果截图:

代码解读:

create_engine( )参数说明:

create_engine(mysql+mysqldb://用户名:密码@localhost:端口/数据库名?编码)
设置数据库的编码方式的时候最好与之前pd.read_csv()中的encoding参数一致

pd.io.sql.to_sql( )参数说明:

(数据框, ‘表名’, con=连接键, schema=‘数据库名’, if_exists=‘操作方式’)
操作方式有append、fail、replace

  • append:如果表存在,则将数据添加到这个表的后面
  • fail:如果表存在就不写入
  • replace:如果存在表,删了,覆盖

该方法有一个缺点:

该方法整体性好,内存消耗大,如果内存大可以一试

 到此这篇关于如何让python把数据框写入MySQL的文章就介绍到这了,更多相关python把数据框写入MySQL内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号