首頁 >後端開發 >Python教學 >Python3讀取Excel資料存入MySQL的方法

Python3讀取Excel資料存入MySQL的方法

不言
不言原創
2018-05-04 14:24:582880瀏覽

這篇文章主要介紹了關於Python3讀取Excel資料存入MySQL的方法,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

Python是數據分析的強大利器。

利用Python做資料分析,第一步就是學習如何讀取日常工作中產生各種excel報表並存入資料中,方便後續資料處理。

這裡跟大家分享python3如何使用xlrd讀取excel,並使用Python3操作pymysql模組將資料存入Mysql中,有需要的朋友們一起來看看。

前言

pymsql是Python中操作MySQL的模組,其使用方法和MySQLdb幾乎相同。但目前pymysql支援python3.x而後者不支援3.x版本。

python操作excel主要用到xlrd和xlwt這兩個函式庫,即xlrd是讀excel,xlwt是寫excel的函式庫。

版本

python >= 3.6

mysql >= 5.7.19

安裝

python、mysql的安裝這裡就不詳細述說了,有需要的朋友自行百度

xlrd : 可以使用pip安裝也可手動下載原始碼安裝,pip安裝:pip install xlrd

pymysql : 可以使用pip安裝也可手動下載原始碼安裝, pip安裝: pip install xlrd

模組

import xlrd
import pymysql
from datetime import datetime
from xlrd import xldate_as_tuple

讀取excel

data = xlrd.open_workbook("D:/sales_data.xls") //读取D盘中名为sales_data的excel表格
table_one = data.sheet_by_index(0)      //根据sheet索引获取sheet的内容
table_two = data.sheet_by_index(1)

建立資料庫連線

db = pymysql.connect("localhost", "root", "gaishi123", "sales_data", use_unicode=True, charset="utf8")

#gaishi123是mysql的root的密碼,sales_data是資料庫名稱

#
for site in sites:
 # 遍历sheet1
 for nrows_one in range(1, int(table_one.nrows)):
  if table_one.cell_value(nrows_one, 0) == site:
   payday = table_one.cell_value(0, 8)
   date = datetime(*xldate_as_tuple(payday, 0))
   payday = date.strftime('%Y/%m/%d')         # 出票日期
   sales = float(table_one.cell_value(nrows_one, 1))     # 销量
   quantity_ticket = int(table_one.cell_value(nrows_one, 2))   # 票数
   rate_electronic = float(table_one.cell_value(nrows_one, 3))  # 电子直销占比
   sales_thanlastweek = float(table_one.cell_value(nrows_one, 4))  # 销量同比上周
   sales_thanlastyear = float(table_one.cell_value(nrows_one, 5))  # 销量同比去年
   break
 # 遍历sheet2
 for nrows_two in range(1, int(table_two.nrows)):
  if table_one.cell_value(nrows_two, 0) == site:
   session = int(table_two.cell_value(nrows_two, 1))     # 访问量
   rate_conversion = float(table_two.cell_value(nrows_two, 2))  # 转化率
   rate_paysuccess = float(table_two.cell_value(nrows_two, 3))  # 支付成功率
   session_thanlastweek = float(table_two.cell_value(nrows_two, 4)) # 访问量同比上周
   break
 # 将数据存入数据库
 sql = "insert into sales_data(SITE, PAYDAY, SALES, QUANTITY_TICKET, RATE_ELECTRONIC, SALES_THANLASTWEEK," \
   "SALES_THANLASTYEAR, SESSION, SESSION_THANLASTWEEK, RATE_CONVERSION, RATE_PAYSUCCESS)" \
   " values ('%s','%s', %f, %d, %f, %f, %f, %d, %f, %f, %f)" %\
   (site, payday, sales, quantity_ticket, rate_electronic, sales_thanlastweek, sales_thanlastyear,
   session, session_thanlastweek, rate_conversion, rate_paysuccess)
 try:
  # 使用 cursor() 方法创建一个游标对象 cursor
  cursor = db.cursor()
  cursor.execute(sql)
 except Exception as e:
  # 发生错误时回滚
  db.rollback()
  print(str(e))
 else:
  db.commit() # 事务提交
  print('事务处理成功')

相關推薦:

python讀取檔案名稱產生list的方法

##python讀取csv檔並把檔案放入一個list中的實例講解

#

以上是Python3讀取Excel資料存入MySQL的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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