- 这是上一篇文章的优化版本,相较于一条一条的执行sql语句,本文中,将excel中所有的数据先写到list列表中
- 在通过函数
一次性写入到数据库中1
cursor.executemany(sql,list) -
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
importpymysqlimportxlrd'''连接数据库args:db_name(数据库名称)returns:db'''defmysql_link(de_name):try:db=pymysql.connect(host="127.0.0.1", user="root",passwd="XXX",db=de_name,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文件放在同一目录下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=[]# 定义列表用来存放数据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)# 将数据暂存在列表# print(i)sql="INSERT INTO "+table_name+" ( bj_shijian,bjr_xingbie,anfa_didian,\zb_x,zb_y,bj_chongfu,jiejing_lb_name,baojing_lb_name,baojing_lx_name,baojing_lx_xl_name,\guanxia_qy_name,guanxian_dw_name,anfa_qulu,anfa_xiaoqu,chujing_dw_name)VALUES(%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)"cursor.executemany(sql,list)# 执行sql语句db.commit()# 提交list.clear()# 清空listprint("worksheets: "+sheet+" has been inserted "+str(row_num)+" datas!")cursor.close()# 关闭连接db.close()if__name__=='__main__':store_to('demo','demo_yangben','qh.xlsx')可以选择传入的数据库,及数据库表名,excel文件名(excel文件和py文件同目录,否则加上路径)
- 每一万条写入一次
-
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
importpymysqlimportxlrdimportsys'''连接数据库args:db_name(数据库名称)returns:db'''defmysql_link(de_name):try:db=pymysql.connect(host="127.0.0.1", user="root",passwd="a12345",db=de_name,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','qh.xlsx')sys.getsizeof()方法监测内存占用
接上一篇--使用python,将excel数据批量导入数据库
最新推荐文章于 2025-11-09 23:26:55 发布
本文介绍了一种高效的方法,即将Excel数据批量导入到MySQL数据库中。通过使用Python的pymysql和xlrd库,文章详细阐述了如何连接数据库、读取Excel文件,并通过executemany函数一次性插入大量数据,提高了数据导入效率。
1393

被折叠的 条评论
为什么被折叠?



