使用python将excel数据导入数据库
使用python将excel数据导入数据库
- 因为需要对数据处理,将excel数据导入到数据库,记录一下过程。
- 使用到的库:xlrd 和 pymysql (如果需要写到excel可以使用xlwt)
- 直接丢代码,使用python3,注释比较清楚。
- 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
importxlrdimportpymysql# import importlib# importlib.reload(sys) #出现呢reload错误使用defopen_excel():try:book=xlrd.open_workbook("XX.xlsx")#文件名,把文件与py文件放在同一目录下except:print("open excel file failed!")try:sheet=book.sheet_by_name("sheet名称")#execl里面的worksheet1returnsheetexcept:print("locate worksheet in excel failed!")#连接数据库try:db=pymysql.connect(host="127.0.0.1",user="root",passwd="XXX",db="XXX",charset='utf8')except:print("could not connect to mysql server")defsearch_count():cursor=db.cursor()select="select count(id) from XXXX"#获取表中xxxxx记录数cursor.execute(select)#执行sql语句line_count=cursor.fetchone()print(line_count[0])definsert_deta():sheet=open_excel()cursor=db.cursor()foriinrange(1, sheet.nrows):#第一行是标题名,对应表中的字段名所以应该从第二行开始,计算机以0开始计数,所以值是1name=sheet.cell(i,0).value#取第i行第0列data=sheet.cell(i,1).value#取第i行第1列,下面依次类推print(name)print(data)value=(name,data)print(value)sql="INSERT INTO XXX(name,data)VALUES(%s,%s)"cursor.execute(sql,value)#执行sql语句db.commit()cursor.close()#关闭连接insert_deta()db.close()#关闭数据print("ok ")XXX里自行修改自己的名称。
- 说明:对于不规则的单元格,例如合并过的单元格会取到空值。
- 有机会把数据库写到excel贴上来。
- 优化了一下这个程序
- 123456789101112131415161718192021222324252627282930313233343536373839404142
importpymysqlimportxlrd# 连接数据库try:db=pymysql.connect(host="127.0.0.1", user="root",passwd="XXX",db="XXX",charset='utf8')except:print("could not connect to mysql server")defopen_excel():try:book=xlrd.open_workbook("XXX.xlsx")#文件名,把文件与py文件放在同一目录下except:print("open excel file failed!")try:sheet=book.sheet_by_name("XXX")#execl里面的worksheet1returnsheetexcept:print("locate worksheet in excel failed!")definsert_deta():sheet=open_excel()cursor=db.cursor()row_num=sheet.nrowsforiinrange(1, row_num):# 第一行是标题名,对应表中的字段名所以应该从第二行开始,计算机以0开始计数,所以值是1row_data=sheet.row_values(i)value=(row_data[0],row_data[1],row_data[2],row_data[3])print(i)sql="INSERT INTO demo_yangben(xxx,xxxx,xxxx,xxxx)VALUES(%s,%s,%s,%s)"cursor.execute(sql, value)# 执行sql语句db.commit()cursor.close()# 关闭连接open_excel()insert_deta() - 再改一下,每一万条数据写入到数据库一次
- 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
importpymysqlimportxlrdimportsys'''连接数据库args:db_name(数据库名称)returns:db'''defmysql_link(de_name):try:db=pymysql.connect(host="127.0.0.1", user="xxx",passwd="xxx",db=xxx,charset='utf8')returndbexcept:print("could not connect to mysql server")'''读取excel函数args:excel_file(excel文件,目录在py文件同目录)returns:book'''defopen_excel(excel_file):try:book=xlrd.open_workbook(excel_file)# 文件名,把文件与py文件放在同一目录下print(sys.getsizeof(book))returnbookexcept:print("open excel file failed!")'''执行插入操作args:db_name(数据库名称)table_name(表名称)excel_file(excel文件名,把文件与py文件放在同一目录下)'''defstore_to(db_name, table_name, excel_file):db=mysql_link(db_name)# 打开数据库连接cursor=db.cursor()# 使用 cursor() 方法创建一个游标对象 cursorbook=open_excel(excel_file)# 打开excel文件sheets=book.sheet_names()# 获取所有sheet表名forsheetinsheets:sh=book.sheet_by_name(sheet)# 打开每一张表row_num=sh.nrowsprint(row_num)list=[]# 定义列表用来存放数据num=0# 用来控制每次插入的数量foriinrange(1, row_num):# 第一行是标题名,对应表中的字段名所以应该从第二行开始,计算机以0开始计数,所以值是1row_data=sh.row_values(i)# 按行获取excel的值value=(row_data[0], row_data[1], row_data[2], row_data[3], row_data[4], row_data[5], \row_data[6], row_data[7], row_data[8], row_data[9], row_data[10], row_data[11], row_data[12],row_data[13], row_data[14])list.append(value)# 将数据暂存在列表num+=1if( num>=10000):# 每一万条数据执行一次插入print(sys.getsizeof(list))sql="INSERT INTO "+table_name+" (time, xingbie, afdd, xzb, yzb, cfbj, jjlbmc, \bjlbmc, bjlxmc, bjlxxlmc, gxqymc,gxdwmc, afql, afxqxx, cjdwmc)\VALUES(%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)"cursor.executemany(sql,list)# 执行sql语句num=0# 计数归零list.clear()# 清空listprint("worksheets: "+sheet+" has been inserted 10000 datas!")print("worksheets: "+sheet+" has been inserted "+str(row_num)+" datas!")db.commit()# 提交cursor.close()# 关闭连接db.close()if__name__=='__main__':store_to('demo','demo_yangben','xxx.xlsx') - 思考,如果数据插入有错误,怎么解决,
- 其实有很多数据库工具可以直接来解决这个问题,注意字符转换的格式就好。
- 批量插入数据请看: https://www.cnblogs.com/longbigbeard/p/9317141.html
使用python将excel数据导入数据库的更多相关文章
- [Asp.net]常见数据导入Excel,Excel数据导入数据库解决方案,总有一款适合你!
引言 项目中常用到将数据导入Excel,将Excel中的数据导入数据库的功能,曾经也查找过相关的内容,将曾经用过的方案总结一下. 方案一 NPOI NPOI 是 POI 项目的 .NET 版本.POI ...
- 如何把excel数据导入数据库
这里介绍2种把excel数据导入oracle数据库的方法. 1. 在excel中生成sql语句. 1)在数据列的右侧,第一行的任何位置输入="insert into table(xx,yyy ...
- C#将Excel数据导入数据库(MySQL或Sql Server)
最近一直很忙,很久没写博客了.今天给大家讲解一下如何用C#将Excel数据导入Excel,同时在文章最后附上如何用sqlserver和mysql工具导入数据. 导入过程大致分为两步: 1.将excel ...
- Excel数据导入数据库
maven依赖 <!--excel相关依赖--> <dependency> <groupId>org.apache.poi</groupId> < ...
- 转:[Asp.net]常见数据导入Excel,Excel数据导入数据库解决方案,总有一款适合你!
引言 项目中常用到将数据导入Excel,将Excel中的数据导入数据库的功能,曾经也查找过相关的内容,将曾经用过的方案总结一下. 方案一 NPOI NPOI 是 POI 项目的 .NET 版本.POI ...
- PHPExcel将Excel数据导入数据库
<?php //PHPExcel读取导入Excel数据到数据库(2003,2007通用)使用方法: //先用excel2array()方法将excel表中的数据存储到数组,在从遍历二维数组将数据 ...
- 利用python将excel数据导入mySQL
主要用到的库有xlrd和pymysql, 注意pymysql不支持python3 篇幅有限,只针对主要操作进行说明 连接数据库 首先pymysql需要连接数据库,我这里连接的是本地数据库(数据库叫ld ...
- 将Excel数据导入数据库
Excel如下,这页工作表名叫“线路” 数据库表如下 using System; using System.Collections.Generic; using System.Linq; using ...
- ASP.NET Excel数据导入数据库
<identity impersonate="true"/> 是指模拟IIS身份验证 導入錯誤時可刪除 protected void btnImport_Click(o ...
随机推荐
- 设计模式(三)Singleton Pattern单例设计模式
1.饿汉式 public class SingletonDemo { private static SingletonDemo s=new SingletonDemo(); private Singl ...
- Linux 端口信息查看
//查看方法①lsof -i:端口号 用于查看某一端口的占用情况,比如查看8000端口使用情况,lsof -i:8000 lsof -i 用以显示符合条件的进程情况,lsof(list open fi ...
- JAVA基础知识总结:二十
一.网络编程基础 1.概念 所谓计算机网络,就是把分布在不同区域的计算机与专门的外部设备使用通信线路连接成一个规模大,功能比较强的网络系统,从而使得计算机之间可以相互通信,共享资源 所谓的网络编程,在 ...
- xlua怎么样hotfix C#中的重写方法???
问题的来源之这样的: 线上项目遇到一个问题,就是子类 override 了父类的一个 virtual 方法,并且调用到了父类里面的 virtual 方法.现在子类 override 的方法里有一些错 ...
- Netty实现简易http_server
Netty可以通过一些handler实现简单的http服务器.具体有三个类,分别是HttpServer.java.ServerHandlerInit.java.BusiHandler.java. 具体 ...
- idea maven环境下 java实现发送邮件验证
1.开通smtp授权 QQ邮箱-设置-账户-开启 得到一个授权码 2.下载javax.email包 maven项目中 pom文件加入: <dependency> <groupId&g ...
- 彻底搞懂 CPU 中的内存结构
https://www.cnblogs.com/YJK923/p/10302180.html
- 守护进程函数——内部的小范围try catch 增强了 while死循环执行的 可靠性
void Watch() { try { LogHelper.WriteLog("WatchServi ...
- PaaS平台型IT运维&运营模式能给企业带来什么?
关注嘉为科技,获取运维新知 什么是PaaS平台型IT自动化运维&运营模式 PaaS平台型IT运维和运维模式是指:将通用的运维能力与具体的运维场景解耦合,将能够复用的,具备独立功能的通用能力纳入 ...
- mat 使用 分析 oom 使用 Eclipse Memory Analyzer 进行堆转储文件分析
概述 对于大型 JAVA 应用程序来说,再精细的测试也难以堵住所有的漏洞,即便我们在测试阶段进行了大量卓有成效的工作,很多问题还是会在生产环境下暴露出来,并且很难在测试环境中进行重现.JVM 能够记录 ...