首頁 >後端開發 >Python教學 >excel轉sqlite在Python下實作的方法介紹

excel轉sqlite在Python下實作的方法介紹

黄舟
黄舟原創
2017-07-17 14:41:461516瀏覽

這篇文章主要介紹了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 ------"

以上是excel轉sqlite在Python下實作的方法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn