
Python實現(xiàn)將數(shù)據(jù)庫一鍵導出為Excel表格的實例
下面小編就為大家?guī)硪黄?a href="http://www.3lll3.cn/view/22818.html" target="_blank">Python實現(xiàn)將數(shù)據(jù)庫一鍵導出為Excel表格的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,
數(shù)據(jù)庫數(shù)據(jù)導出為excel表格,也可以說是一個很常用的功能了。畢竟不是任何人都懂數(shù)據(jù)庫操作語句的。
下面先來看看完成的效果吧。
數(shù)據(jù)源
導出結(jié)果
依賴
由于是Python實現(xiàn)的,所以需要有Python環(huán)境的支持
Python2.7.11
我的Python環(huán)境是2.7.11。雖然你用的可能是3.5版本,但是思想是一致的。
xlwt
pip install xlwt
MySQLdb
pip install MySQLdb
如果上述方式不成功的話,可以到sourceforge官網(wǎng)上去下載windows上的msi版本或者使用源碼自行編譯。
數(shù)據(jù)庫相關(guān)
本次試驗,數(shù)據(jù)庫相關(guān)的其實也就是如何使用Python操作數(shù)據(jù)庫而已,知識點也很少,下述為我們本次用到的一些簡單的語句。
連接
conn = MySQLdb.connect(host='localhost',user='root',passwd='mysql',db='test',charset='utf8')
這里值得我們一提的就是最后一個參數(shù)的使用,不然從數(shù)據(jù)庫中取出的數(shù)據(jù)就會使亂碼。關(guān)于亂碼問題,如果還有不明白的地方,不妨看下這篇文章 淺談編碼,解碼,亂碼的問題
獲取字段信息
fields = cursor.description
至于cursor,是我們操作數(shù)據(jù)庫的核心。游標的特點就是一旦遍歷過該條數(shù)據(jù),便不可返回。但是我們也可以手動的改變其位置。
cursor.scroll(0,mode='absolute')來重置游標的位置
獲取數(shù)據(jù)
獲取數(shù)據(jù)簡直更是輕而易舉,但是我們必須在心里明白,數(shù)據(jù)項是一個類似于二維數(shù)組的存在。我們獲取每一個cell項的時候應該注意。
results = cursor.fetchall()
Excel基礎
同樣,這里講解的也是如何使用Python來操作excel數(shù)據(jù)。
workbook
工作薄的概念我們必須要明確,其是我們工作的基礎。與下文的sheet相對應,workbook是sheet賴以生存的載體。
workbook = xlwt.Workbook()
sheet
我們所有的操作,都是在sheet上進行的。
sheet = workbook.add_sheet(‘table_message',cell_overwrite_ok=True)
對于workbook 和sheet,如果對此有點模糊。不妨這樣進行假設。
日常生活中記賬的時候,我們都會有一個賬本,這就是workbook。而我們記賬則是記錄在一張張的表格上面,這些表格就是我們看到的sheet。一個賬本上可以有很多個表格,也可以只是一個表格。這樣就很容易理解了吧。 :-)
案例
下面看一個小案例。
# coding:utf8
import sys
reload(sys)
sys.setdefaultencoding('utf8')
# __author__ = '郭 璞'
# __date__ = '2016/8/20'
# __Desc__ = 從數(shù)據(jù)庫中導出數(shù)據(jù)到excel數(shù)據(jù)表中
import xlwt
import MySQLdb
conn = MySQLdb.connect('localhost','root','mysql','test',charset='utf8')
cursor = conn.cursor()
count = cursor.execute('select * from message')
print count
# 重置游標的位置
cursor.scroll(0,mode='absolute')
# 搜取所有結(jié)果
results = cursor.fetchall()
# 獲取MYSQL里面的數(shù)據(jù)字段名稱
fields = cursor.description
workbook = xlwt.Workbook()
sheet = workbook.add_sheet('table_message',cell_overwrite_ok=True)
# 寫上字段信息
for field in range(0,len(fields)):
sheet.write(0,field,fields[field][0])
# 獲取并寫入數(shù)據(jù)段信息
row = 1
col = 0
for row in range(1,len(results)+1):
for col in range(0,len(fields)):
sheet.write(row,col,u'%s'%results[row-1][col])
workbook.save(r'./readout.xlsx')
封裝
為了使用上的方便,現(xiàn)將其封裝成一個容易調(diào)用的函數(shù)。
封裝之后
# coding:utf8
import sys
reload(sys)
sys.setdefaultencoding('utf8')
# __author__ = '郭 璞'
# __date__ = '2016/8/20'
# __Desc__ = 從數(shù)據(jù)庫中導出數(shù)據(jù)到excel數(shù)據(jù)表中
import xlwt
import MySQLdb
def export(host,user,password,dbname,table_name,outputpath):
conn = MySQLdb.connect(host,user,password,dbname,charset='utf8')
cursor = conn.cursor()
count = cursor.execute('select * from '+table_name)
print count
# 重置游標的位置
cursor.scroll(0,mode='absolute')
# 搜取所有結(jié)果
results = cursor.fetchall()
# 獲取MYSQL里面的數(shù)據(jù)字段名稱
fields = cursor.description
workbook = xlwt.Workbook()
sheet = workbook.add_sheet('table_'+table_name,cell_overwrite_ok=True)
# 寫上字段信息
for field in range(0,len(fields)):
sheet.write(0,field,fields[field][0])
# 獲取并寫入數(shù)據(jù)段信息
row = 1
col = 0
for row in range(1,len(results)+1):
for col in range(0,len(fields)):
sheet.write(row,col,u'%s'%results[row-1][col])
workbook.save(outputpath)
# 結(jié)果測試
if __name__ == "__main__":
export('localhost','root','mysql','test','datetest',r'datetest.xlsx')
測試結(jié)果
id name date
1 dlut 2016-07-06
2 清華大學 2016-07-03
3 北京大學 2016-07-28
4 Mark 2016-08-20
5 Tom 2016-08-19
6 Jane 2016-08-21
總結(jié)
回顧一下,本次試驗用到了哪些知識點。
?Python簡易操作數(shù)據(jù)庫
?Python簡易操作Excel
?數(shù)據(jù)庫取出數(shù)據(jù)亂碼問題解決之添加charset=utf-8
?以二維數(shù)組的角度來處理獲取到的結(jié)果集。
以上這篇Python實現(xiàn)將數(shù)據(jù)庫一鍵導出為Excel表格的實例就是小編分享給大家的全部內(nèi)容了
數(shù)據(jù)分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
LSTM 模型輸入長度選擇技巧:提升序列建模效能的關(guān)鍵? 在循環(huán)神經(jīng)網(wǎng)絡(RNN)家族中,長短期記憶網(wǎng)絡(LSTM)憑借其解決長序列 ...
2025-07-11CDA 數(shù)據(jù)分析師報考條件詳解與準備指南? ? 在數(shù)據(jù)驅(qū)動決策的時代浪潮下,CDA 數(shù)據(jù)分析師認證愈發(fā)受到矚目,成為眾多有志投身數(shù) ...
2025-07-11數(shù)據(jù)透視表中兩列相乘合計的實用指南? 在數(shù)據(jù)分析的日常工作中,數(shù)據(jù)透視表憑借其強大的數(shù)據(jù)匯總和分析功能,成為了 Excel 用戶 ...
2025-07-11尊敬的考生: 您好! 我們誠摯通知您,CDA Level I和 Level II考試大綱將于 2025年7月25日 實施重大更新。 此次更新旨在確保認 ...
2025-07-10BI 大數(shù)據(jù)分析師:連接數(shù)據(jù)與業(yè)務的價值轉(zhuǎn)化者? ? 在大數(shù)據(jù)與商業(yè)智能(Business Intelligence,簡稱 BI)深度融合的時代,BI ...
2025-07-10SQL 在預測分析中的應用:從數(shù)據(jù)查詢到趨勢預判? ? 在數(shù)據(jù)驅(qū)動決策的時代,預測分析作為挖掘數(shù)據(jù)潛在價值的核心手段,正被廣泛 ...
2025-07-10數(shù)據(jù)查詢結(jié)束后:分析師的收尾工作與價值深化? ? 在數(shù)據(jù)分析的全流程中,“query end”(查詢結(jié)束)并非工作的終點,而是將數(shù) ...
2025-07-10CDA 數(shù)據(jù)分析師考試:從報考到取證的全攻略? 在數(shù)字經(jīng)濟蓬勃發(fā)展的今天,數(shù)據(jù)分析師已成為各行業(yè)爭搶的核心人才,而 CDA(Certi ...
2025-07-09【CDA干貨】單樣本趨勢性檢驗:捕捉數(shù)據(jù)背后的時間軌跡? 在數(shù)據(jù)分析的版圖中,單樣本趨勢性檢驗如同一位耐心的偵探,專注于從單 ...
2025-07-09year_month數(shù)據(jù)類型:時間維度的精準切片? ? 在數(shù)據(jù)的世界里,時間是最不可或缺的維度之一,而year_month數(shù)據(jù)類型就像一把精準 ...
2025-07-09CDA 備考干貨:Python 在數(shù)據(jù)分析中的核心應用與實戰(zhàn)技巧? ? 在 CDA 數(shù)據(jù)分析師認證考試中,Python 作為數(shù)據(jù)處理與分析的核心 ...
2025-07-08SPSS 中的 Mann-Kendall 檢驗:數(shù)據(jù)趨勢與突變分析的有力工具? ? ? 在數(shù)據(jù)分析的廣袤領(lǐng)域中,準確捕捉數(shù)據(jù)的趨勢變化以及識別 ...
2025-07-08備戰(zhàn) CDA 數(shù)據(jù)分析師考試:需要多久?如何規(guī)劃? CDA(Certified Data Analyst)數(shù)據(jù)分析師認證作為國內(nèi)權(quán)威的數(shù)據(jù)分析能力認證 ...
2025-07-08LSTM 輸出不確定的成因、影響與應對策略? 長短期記憶網(wǎng)絡(LSTM)作為循環(huán)神經(jīng)網(wǎng)絡(RNN)的一種變體,憑借獨特的門控機制,在 ...
2025-07-07統(tǒng)計學方法在市場調(diào)研數(shù)據(jù)中的深度應用? 市場調(diào)研是企業(yè)洞察市場動態(tài)、了解消費者需求的重要途徑,而統(tǒng)計學方法則是市場調(diào)研數(shù) ...
2025-07-07CDA數(shù)據(jù)分析師證書考試全攻略? 在數(shù)字化浪潮席卷全球的當下,數(shù)據(jù)已成為企業(yè)決策、行業(yè)發(fā)展的核心驅(qū)動力,數(shù)據(jù)分析師也因此成為 ...
2025-07-07剖析 CDA 數(shù)據(jù)分析師考試題型:解鎖高效備考與答題策略? CDA(Certified Data Analyst)數(shù)據(jù)分析師考試作為衡量數(shù)據(jù)專業(yè)能力的 ...
2025-07-04SQL Server 字符串截取轉(zhuǎn)日期:解鎖數(shù)據(jù)處理的關(guān)鍵技能? 在數(shù)據(jù)處理與分析工作中,數(shù)據(jù)格式的規(guī)范性是保證后續(xù)分析準確性的基礎 ...
2025-07-04CDA 數(shù)據(jù)分析師視角:從數(shù)據(jù)迷霧中探尋商業(yè)真相? 在數(shù)字化浪潮席卷全球的今天,數(shù)據(jù)已成為企業(yè)決策的核心驅(qū)動力,CDA(Certifie ...
2025-07-04CDA 數(shù)據(jù)分析師:開啟數(shù)據(jù)職業(yè)發(fā)展新征程? ? 在數(shù)據(jù)成為核心生產(chǎn)要素的今天,數(shù)據(jù)分析師的職業(yè)價值愈發(fā)凸顯。CDA(Certified D ...
2025-07-03