溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么使用python將excel數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫

發(fā)布時間:2021-04-27 12:58:55 來源:億速云 閱讀:1055 作者:小新 欄目:開發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)怎么使用python將excel數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

python主要應(yīng)用領(lǐng)域有哪些

1、云計算,典型應(yīng)用OpenStack。2、WEB前端開發(fā),眾多大型網(wǎng)站均為Python開發(fā)。3.人工智能應(yīng)用,基于大數(shù)據(jù)分析和深度學(xué)習(xí)而發(fā)展出來的人工智能本質(zhì)上已經(jīng)無法離開python。4、系統(tǒng)運維工程項目,自動化運維的標配就是python+Django/flask。5、金融理財分析,量化交易,金融分析。6、大數(shù)據(jù)分析。

因為需要對數(shù)據(jù)處理,將excel數(shù)據(jù)導(dǎo)入到數(shù)據(jù)庫,記錄一下過程。

使用到的庫:xlrd 和 pymysql (如果需要寫到excel可以使用xlwt)

直接丟代碼,使用python3,注釋比較清楚。

import xlrd
import pymysql
# import importlib
# importlib.reload(sys) #出現(xiàn)呢reload錯誤使用
def open_excel():
  try:
    book = xlrd.open_workbook("XX.xlsx") #文件名,把文件與py文件放在同一目錄下
  except:
    print("open excel file failed!")
  try:
    sheet = book.sheet_by_name("sheet名稱")  #execl里面的worksheet1
    return sheet
  except:
    print("locate worksheet in excel failed!") 
 #連接數(shù)據(jù)庫
try:
  db = pymysql.connect(host="127.0.0.1",user="root",
    passwd="XXX",
    db="XXX",
    charset='utf8')
except:
  print("could not connect to mysql server")
 
def search_count():
  cursor = db.cursor()
  select = "select count(id) from XXXX" #獲取表中xxxxx記錄數(shù)
  cursor.execute(select) #執(zhí)行sql語句
  line_count = cursor.fetchone()
  print(line_count[0])
 
 
def insert_deta():
  sheet = open_excel()
  cursor = db.cursor()
  for i in range(1, sheet.nrows): #第一行是標題名,對應(yīng)表中的字段名所以應(yīng)該從第二行開始,計算機以0開始計數(shù),所以值是1
 
    name = sheet.cell(i,0).value #取第i行第0列
    data = sheet.cell(i,1).value#取第i行第1列,下面依次類推
    print(name)
    print(data)
    value = (name,data)
    print(value)
    sql = "INSERT INTO XXX(name,data)VALUES(%s,%s)"
    cursor.execute(sql,value) #執(zhí)行sql語句
    db.commit()
  cursor.close() #關(guān)閉連接
insert_deta()
db.close()#關(guān)閉數(shù)據(jù)
print ("ok ")

XXX里自行修改自己的名稱。

說明:對于不規(guī)則的單元格,例如合并過的單元格會取到空值。

優(yōu)化了一下這個程序

import pymysql
import xlrd 
# 連接數(shù)據(jù)庫
try:
  db = pymysql.connect(host="127.0.0.1", user="root",
             passwd="XXX",
             db="XXX",
             charset='utf8')
except:
  print("could not connect to mysql server") 
def open_excel():
  try:
    book = xlrd.open_workbook("XXX.xlsx") #文件名,把文件與py文件放在同一目錄下
  except:
    print("open excel file failed!")
  try:
    sheet = book.sheet_by_name("XXX")  #execl里面的worksheet1
    return sheet
  except:
    print("locate worksheet in excel failed!") 
def insert_deta():
  sheet = open_excel()
  cursor = db.cursor()
  row_num = sheet.nrows
  for i in range(1, row_num): # 第一行是標題名,對應(yīng)表中的字段名所以應(yīng)該從第二行開始,計算機以0開始計數(shù),所以值是1
    row_data = sheet.row_values(i)
    value = (row_data[0],row_data[1],row_data[2],row_data[3])
    print(i)
    sql = "INSERT INTO demo_yangben(xxx,xxxx,xxxx,xxxx)VALUES(%s,%s,%s,%s)"
    cursor.execute(sql, value) # 執(zhí)行sql語句
    db.commit()
  cursor.close() # 關(guān)閉連接
open_excel()
insert_deta()

再改一下,每一萬條數(shù)據(jù)寫入到數(shù)據(jù)庫一次

import pymysql
import xlrd
import sys 
'''
  連接數(shù)據(jù)庫
  args:db_name(數(shù)據(jù)庫名稱)
  returns:db
 
''' 
def mysql_link(de_name):
  try:
    db = pymysql.connect(host="127.0.0.1", user="xxx",
               passwd="xxx",
               db=xxx,
               charset='utf8')
    return db
  except:
    print("could not connect to mysql server")
 
'''
  讀取excel函數(shù)
  args:excel_file(excel文件,目錄在py文件同目錄)
  returns:book
'''
 
 
def open_excel(excel_file):
  try:
    book = xlrd.open_workbook(excel_file) # 文件名,把文件與py文件放在同一目錄下
    print(sys.getsizeof(book))
    return book
  except:
    print("open excel file failed!")
 
 
'''
  執(zhí)行插入操作
  args:db_name(數(shù)據(jù)庫名稱)
     table_name(表名稱)
     excel_file(excel文件名,把文件與py文件放在同一目錄下)
 
'''
 
 
def store_to(db_name, table_name, excel_file):
  db = mysql_link(db_name) # 打開數(shù)據(jù)庫連接
  cursor = db.cursor() # 使用 cursor() 方法創(chuàng)建一個游標對象 cursor
 
  book = open_excel(excel_file) # 打開excel文件
  sheets = book.sheet_names() # 獲取所有sheet表名
  for sheet in sheets:
    sh = book.sheet_by_name(sheet) # 打開每一張表
    row_num = sh.nrows
    print(row_num)
    list = [] # 定義列表用來存放數(shù)據(jù)
    num = 0 # 用來控制每次插入的數(shù)量
    for i in range(1, row_num): # 第一行是標題名,對應(yīng)表中的字段名所以應(yīng)該從第二行開始,計算機以0開始計數(shù),所以值是1
      row_data = sh.row_values(i) # 按行獲取excel的值
      value = (row_data[0], row_data[1], row_data[2], row_data[3], row_data[4], row_data[5], \
           row_data[6], row_data[7], row_data[8], row_data[9], row_data[10], row_data[11], row_data[12],
           row_data[13], row_data[14])
      list.append(value) # 將數(shù)據(jù)暫存在列表
      num += 1
      if( num>= 10000 ): # 每一萬條數(shù)據(jù)執(zhí)行一次插入
        print(sys.getsizeof(list))
        sql = "INSERT INTO " + table_name + " (time, xingbie, afdd, xzb, yzb, cfbj, jjlbmc, \
        bjlbmc, bjlxmc, bjlxxlmc, gxqymc,gxdwmc, afql, afxqxx, cjdwmc)\
        VALUES(%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)"
        cursor.executemany(sql, list) # 執(zhí)行sql語句
 
        num = 0 # 計數(shù)歸零
        list.clear() # 清空list
        print("worksheets: " + sheet + " has been inserted 10000 datas!")
 
  print("worksheets: " + sheet + " has been inserted " + str(row_num) + " datas!")
  db.commit() # 提交
  cursor.close() # 關(guān)閉連接
  db.close() 
 if __name__ == '__main__':
  store_to('demo', 'demo_yangben', 'xxx.xlsx')

感謝各位的閱讀!關(guān)于“怎么使用python將excel數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI