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


本文摘自php中文网,作者黄舟,侵删。

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

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

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

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

先看excel内容:

然后是生成的数据库:

下面是源代码:

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

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

以上就是excel转sqlite在Python下实现的方法介绍的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

会java学Python快吗

Python如何打印99乘法表

Python实现获取前100组勾股数的方法

Python如何删除除字母和数字之外的所有字符?(代码示例)

format在Python中是什么意思

Python 读入多行数据

Python numpy怎么提取矩阵的指定行列

Python爬虫如何设置代理

Python图像处理二值化方法实例云集

详解神经网络理论基础及Python实现方法

更多相关阅读请进入《Python》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...