您好,欢迎来到飒榕旅游知识分享网。
搜索
您的当前位置:首页excel转sqlite在Python下实现的方法介绍

excel转sqlite在Python下实现的方法介绍

来源:飒榕旅游知识分享网
这篇文章主要介绍了Python实现excel转sqlite的方法,结合实例形式分析了Python基于第三方库xlrd读取Excel文件及写入sqlite的相关操作技巧,需要的朋友可以参考下

本文实例讲述了Python实现excel转sqlite的方法。分享给大家供大家参考,具体如下:

Python环境的安装配置就不说了,个人喜欢pydev的开发环境。

python解析excel需要使用第三方的库,这里选择使用xlrd

先看excel内容:

然后是生成的数据库:

下面是源代码:

#!/usr/bin/python
# encoding=utf-8
'''''
Created on 2013-4-2
@author: ting
'''
from xlrd import open_workbook
import sqlite3
import types
def read_excel(sheet):
 # 判断有效sheet
 if sheet.nrows > 0 and sheet.ncols > 0:
 for row in range(1, sheet.nrows):
 row_data = []
 for col in range(sheet.ncols):
 data = sheet.cell(row, col).value
 # excel表格内容数据类型转换 float->int,unicode->utf-8
 if type(data) is types.UnicodeType: data = data.encode("utf-8")
 elif type(data) is types.FloatType: data = int(data)
 row_data.append(data)
 check_data_length(row_data)
# 检查row_data长度
def check_data_length(row_data):
 if len(row_data) == 3:
 insert_sqlite(row_data)
def insert_sqlite(row_data):
 # 打开数据库(不存在时会创建数据库)
 con = sqlite3.connect("test.db")
 cur = con.cursor()
 try:
 cur.execute("create table if not exists contacts(_id integer primary key "
 "autoincrement,name text,age integer,number integer)")
 # 插入数据不要使用拼接字符串的方式,容易收到sql注入攻击
 cur.execute("insert into contacts(name,age,number) values(?,?,?)", row_data)
 con.commit()
 except sqlite3.Error as e:
 print "An error occurred: %s", e.args[0]
 finally:
 cur.close
 con.close
xls_file = "test.xls"
book = open_workbook(xls_file)
for sheet in book.sheets():
 read_excel(sheet)
print "------ Done ------"

Copyright © 2019- sarr.cn 版权所有 赣ICP备2024042794号-1

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务