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对两个有序列表进行合并和排序的例子
Jun 13 Python
python通过字典dict判断指定键值是否存在的方法
Mar 21 Python
举例讲解Python中字典的合并值相加与异或对比
Jun 04 Python
Python进阶-函数默认参数(详解)
May 18 Python
基于hashlib模块--加密(详解)
Jun 21 Python
利用python打印出菱形、三角形以及矩形的方法实例
Aug 08 Python
python虚拟环境virtualenv的使用教程
Oct 20 Python
Python冲顶大会 快来答题!
Jan 17 Python
python3调用R的示例代码
Feb 23 Python
Python计算IV值的示例讲解
Feb 28 Python
pytorch快速搭建神经网络_Sequential操作
Jun 17 Python
Python CategoricalDtype自定义排序实现原理解析
Sep 11 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
去除php注释和去除空格函数分享
2014/03/13 PHP
PHP实现支持加盐的图片加密解密
2016/09/09 PHP
PHP设计模式之装饰器模式实例详解
2018/02/07 PHP
超级强大的表单验证
2006/06/26 Javascript
E3 tree 1.6在Firefox下显示问题的修复方法
2013/01/30 Javascript
javascript通过navigator.userAgent识别各种浏览器
2013/10/25 Javascript
jquery等待效果示例
2014/05/01 Javascript
javascript字符串与数组转换汇总
2015/05/26 Javascript
学习vue.js表单控件绑定操作
2016/12/05 Javascript
ng2学习笔记之bootstrap中的component使用教程
2017/03/09 Javascript
Vuex的基本概念、项目搭建以及入坑点
2018/11/04 Javascript
ES6 let和const定义变量与常量的应用实例分析
2019/06/27 Javascript
浅谈vue异步数据影响页面渲染
2019/10/29 Javascript
react基本安装与测试示例
2020/04/27 Javascript
详解JavaScript的this指向和绑定
2020/09/08 Javascript
[05:00]TI9战队采访 - Royal Never Give Up
2019/08/20 DOTA
python中cPickle用法例子分享
2014/01/03 Python
python实现网页链接提取的方法分享
2014/02/25 Python
详解Python中expandtabs()方法的使用
2015/05/18 Python
放弃 Python 转向 Go语言有人给出了 9 大理由
2017/10/20 Python
Python实现读取txt文件并画三维图简单代码示例
2017/12/09 Python
Python迭代器定义与简单用法分析
2018/04/30 Python
Matplotlib 生成不同大小的subplots实例
2018/05/25 Python
Python将主机名转换为IP地址的方法
2019/08/14 Python
css3 实现圆形旋转倒计时
2018/02/24 HTML / CSS
Ellos丹麦:时尚和服装在线
2016/09/19 全球购物
GUESS盖尔斯法国官网:美国时尚品牌
2016/09/23 全球购物
KIKO MILANO西班牙官网:意大利领先的化妆品和护肤品品牌
2019/05/03 全球购物
豪华床上用品、床单和浴室必需品:Peacock Alley
2019/09/04 全球购物
三年级数学教学反思
2014/01/31 职场文书
玲玲的画教学反思
2014/02/04 职场文书
法学专业毕业实习自我鉴定2014
2014/09/27 职场文书
检讨书怎么写
2015/05/07 职场文书
初中班主任工作随笔
2015/08/15 职场文书
2015年秋学期教研工作总结
2015/10/14 职场文书
Spring Boot DevTools 全局配置学习指南
2022/03/31 Java/Android