Python实现excel转sqlite的方法


Posted in Python onJuly 17, 2017

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

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

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

先看excel内容:

Python实现excel转sqlite的方法

然后是生成的数据库:

Python实现excel转sqlite的方法

下面是源代码:

#!/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 ------"

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python网络爬虫出现乱码问题的解决方法
Jan 05 Python
Python连接数据库学习之DB-API详解
Feb 07 Python
Python基于百度AI的文字识别的示例
Apr 21 Python
python3第三方爬虫库BeautifulSoup4安装教程
Jun 19 Python
浅谈django rest jwt vue 跨域问题
Oct 26 Python
Python3.5面向对象编程图文与实例详解
Apr 24 Python
Falsk 与 Django 过滤器的使用与区别详解
Jun 04 Python
在cmd中查看python的安装路径方法
Jul 03 Python
pytorch 在sequential中使用view来reshape的例子
Aug 20 Python
python不使用for计算两组、多个矩形两两间的iou方式
Jan 18 Python
解决Tensorboard 不显示计算图graph的问题
Feb 15 Python
python爬虫学习笔记之Beautifulsoup模块用法详解
Apr 09 Python
PyChar学习教程之自定义文件与代码模板详解
Jul 17 #Python
Python实现将sqlite数据库导出转成Excel(xls)表的方法
Jul 17 #Python
Python下实现的RSA加密/解密及签名/验证功能示例
Jul 17 #Python
Python 的类、继承和多态详解
Jul 16 #Python
PyQt 线程类 QThread使用详解
Jul 16 #Python
Pycharm技巧之代码跳转该如何回退
Jul 16 #Python
Python基础教程之浅拷贝和深拷贝实例详解
Jul 15 #Python
You might like
Discuz! Passport 通行证整合
2008/03/27 PHP
php中利用str_pad函数生成数字递增形式的产品编号
2013/09/30 PHP
PHP生成json和xml类型接口数据格式
2015/05/17 PHP
JS+PHP实现用户输入数字后显示最大的值及所在位置
2017/06/19 PHP
在laravel中实现事务回滚的方法
2019/10/10 PHP
PHP实现微信提现功能(微信商城)
2019/11/21 PHP
一些常用弹出窗口/拖放/异步文件上传等实用代码
2013/01/06 Javascript
JavaScript利用append添加元素报错的解决方法
2014/07/01 Javascript
AngularJS入门教程中SQL实例详解
2016/07/27 Javascript
BootStrap 下拉菜单点击之后不会出现下拉菜单(下拉菜单不弹出)的解决方案
2016/12/14 Javascript
js实现悬浮窗效果(支持拖动)
2017/03/09 Javascript
通过学习bootstrop导航条学会修改bootstrop颜色基调
2017/06/11 Javascript
浅谈react 同构之样式直出
2017/11/07 Javascript
koa2使用ejs和nunjucks作为模板引擎的使用
2018/11/27 Javascript
彻底搞懂并解决vue-cli4中图片显示的问题实现
2020/08/31 Javascript
聊聊vue 中的v-on参数问题
2021/01/29 Vue.js
python解析xml模块封装代码
2014/02/07 Python
详解Python中的文件操作
2016/08/28 Python
Python探索之爬取电商售卖信息代码示例
2017/10/27 Python
python 除法保留两位小数点的方法
2018/07/16 Python
Python读取excel中的图片完美解决方法
2018/07/27 Python
python 对多个csv文件分别进行处理的方法
2019/01/07 Python
dpn网络的pytorch实现方式
2020/01/14 Python
OpenCV读取与写入图片的实现
2020/10/13 Python
VSCode中autopep8无法运行问题解决方案(提示Error: Command failed,usage)
2021/03/02 Python
HTML5 Canvas玩转酷炫大波浪进度图效果实例(附demo)
2016/12/14 HTML / CSS
使用HTML5加载音频和视频的实现代码
2020/11/30 HTML / CSS
优秀团员个人的自我评价
2013/10/02 职场文书
物业管理大学生个人的自我评价
2013/10/10 职场文书
建筑个人求职信范文
2014/01/25 职场文书
开学典礼感言
2014/02/16 职场文书
党性心得体会
2014/09/03 职场文书
护士求职自荐信
2015/03/25 职场文书
2016教师给学生的毕业寄语
2015/12/04 职场文书
详解Redis基本命令与使用场景
2021/06/01 Redis
Python实现列表拼接和去重的三种方式
2021/07/02 Python