天天看點

python3 excel讀寫_Python3讀取Excel資料存入My

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