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
讀取exceldata = 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('事務處理成功')