日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

使用Python實(shí)現(xiàn)將多表分批次從數(shù)據(jù)庫導(dǎo)出到Excel

瀏覽:28日期:2022-07-25 14:15:56

一、應(yīng)用場景

為了避免反復(fù)的手手工從后臺數(shù)據(jù)庫導(dǎo)出某些數(shù)據(jù)表到Excel文件、高效率到多份離線數(shù)據(jù)。

二、功能事項(xiàng)

支持一次性導(dǎo)出多個數(shù)據(jù)源表、自動獲取各表的字段名。

支持控制批次的寫入速率。例如:每5000行一個批次寫入到excel。

支持結(jié)構(gòu)相同的表導(dǎo)入到同一個Excel文件。可適用于經(jīng)過水平切分后的分布式表。

三、主要實(shí)現(xiàn)

1、概覽

A[創(chuàng)建類] -->|方法1| B(創(chuàng)建數(shù)據(jù)庫連接)A[創(chuàng)建類] -->|方法2| C(取查詢結(jié)果集)A[創(chuàng)建類] -->|方法3| D(利用句柄寫入Excel)A[創(chuàng)建類] -->|方法4| E(讀取多個源表)

B(創(chuàng)建數(shù)據(jù)庫連接) -->U(調(diào)用示例)C(取查詢結(jié)果集) -->U(調(diào)用示例)D(利用句柄寫入Excel) -->U(調(diào)用示例)E(讀取多個源表) -->U(調(diào)用示例)

2、主要方法

首先需要安裝第三方庫pymssql實(shí)現(xiàn)對SQLServer的連接訪問,自定義方法__getConn()需要指定如下五個參數(shù):服務(wù)器host、登錄用戶名user、登錄密碼pwd、指定的數(shù)據(jù)庫db、字符編碼charset。連接成功后,通過cursor()獲取游標(biāo)對象,它將用來執(zhí)行數(shù)據(jù)庫腳本,并得到返回結(jié)果集和數(shù)據(jù)總量。

創(chuàng)建數(shù)據(jù)庫連接和執(zhí)行SQL的源碼:

def __init__(self,host,user,pwd,db): self.host = host self.user = user self.pwd = pwd self.db = db def __getConn(self): if not self.db: raise(NameError,’沒有設(shè)置數(shù)據(jù)庫信息’) self.conn = pymssql.connect(host=self.host, user=self.user, password=self.pwd, database=self.db, charset=’utf8’) cur = self.conn.cursor() if not cur: raise(NameError,’連接數(shù)據(jù)庫失敗’) else: return cur

3、方法3中寫入Excel時,注意一定要用到Pandas中的公共句柄ExcelWriter對象writer。當(dāng)數(shù)據(jù)被分批多次寫入同一個文件時,如果直接使用to_excel()方法,則前面批次的結(jié)果集將會被后續(xù)結(jié)果覆蓋。增加了這個公共句柄限制后,后面的寫入會累加到前面寫入的數(shù)據(jù)尾部行,而不是全部覆蓋。

writer = pd.ExcelWriter(file)df_fetch_data[rs_startrow:i*N].to_excel(writer, header=isHeader, index=False, startrow=startRow)

分批次寫入到目標(biāo)Excel時的另一個要注意的參數(shù)是寫入行startrow的設(shè)置。每次寫入完成后需要重新指下一批次數(shù)據(jù)的初始位置值。每個批次的數(shù)據(jù)會記錄各自的所屬批次信息。

利用關(guān)鍵字參數(shù)**args 指定多個數(shù)據(jù)源表和數(shù)據(jù)庫連接。

def exportToExcel(self, **args): for sourceTB in args[’sourceTB’]:arc_dict = dict( sourceTB = sourceTB, path=args[’path’], startRow=args[’startRow’], isHeader=args[’isHeader’], batch=args[’batch’] ) print(’n當(dāng)前導(dǎo)出的數(shù)據(jù)表為:%s’ %(sourceTB)) self.writeToExcel(**arc_dict) return ’success’

四、先用類MSSQL創(chuàng)建對象,再定義關(guān)鍵字參數(shù)args,最終調(diào)用方法導(dǎo)出到文件即完成數(shù)據(jù)導(dǎo)出。

#!/usr/bin/env python# coding: utf-8# 主要功能:分批次導(dǎo)出大數(shù)據(jù)量、結(jié)構(gòu)相同的數(shù)據(jù)表到excel # 導(dǎo)出多個表的數(shù)據(jù)到各自的文件, # 目前問題:to_excel 雖然設(shè)置了分批寫入,但先前的數(shù)據(jù)會被下一次寫入覆蓋,# 利用Pandas包中的ExcelWriter()方法增加一個公共句柄,在寫入新的數(shù)據(jù)之時保留原來寫入的數(shù)據(jù),等到把所有的數(shù)據(jù)都寫進(jìn)去之后關(guān)閉這個句柄import pymssql import pandas as pd import datetime import math class MSSQL(object): def __init__(self,host,user,pwd,db): self.host = host self.user = user self.pwd = pwd self.db = db def __getConn(self): if not self.db: raise(NameError,’沒有設(shè)置數(shù)據(jù)庫信息’) self.conn = pymssql.connect(host=self.host, user=self.user, password=self.pwd, database=self.db, charset=’utf8’) cur = self.conn.cursor() if not cur: raise(NameError,’連接數(shù)據(jù)庫失敗’) else: return cur def executeQuery(self,sql): cur = self.__getConn() cur.execute(sql) # 獲取所有數(shù)據(jù)集 # fetchall()獲取結(jié)果集中的剩下的所有行 # 如果數(shù)據(jù)量太大,是否需要分批插入 resList, rowcount = cur.fetchall(),cur.rowcount self.conn.close() return (resList, rowcount) # 導(dǎo)出單個數(shù)據(jù)表到excel def writeToExcel(self,**args): sourceTB = args[’sourceTB’] columns = args.get(’columns’) path=args[’path’] fname=args.get(’fname’) startRow=args[’startRow’] isHeader=args[’isHeader’] N=args[’batch’] # 獲取指定源數(shù)據(jù)列 if columns is None: columns_select = ’ * ’ else: columns_select = ’,’.join(columns) if fname is None: fname=sourceTB+’_exportData.xlsx’ file = path + fname # 增加一個公共句柄,寫入新數(shù)據(jù)時,保留原數(shù)據(jù) writer = pd.ExcelWriter(file) sql_select = ’select ’+ columns_select + ’ from ’+ sourceTB fetch_data, rowcount = self.executeQuery(sql_select) # print(rowcount) df_fetch_data = pd.DataFrame(fetch_data) # 一共有roucount行數(shù)據(jù),每N行一個batch提交寫入到excel times = math.floor(rowcount/N) i = 1 rs_startrow = 0 # 當(dāng)總數(shù)據(jù)量 > 每批插入的數(shù)據(jù)量時 print(i, times) is_while=0 while i <= times: is_while = 1 # 如果是首次,且指定輸入標(biāo)題,則有標(biāo)題 if i==1:# isHeader = TruestartRow = 1 else:# isHeader = FalsestartRow+=N # 切片取指定的每個批次的數(shù)據(jù)行 ,前閉后開 # startrow: 寫入到目標(biāo)文件的起始行。0表示第1行,1表示第2行。。。 df_fetch_data[’batch’] = ’batch’+str(i) df_fetch_data[rs_startrow:i*N].to_excel(writer, header=isHeader, index=False, startrow=startRow) print(’第’,str(i),’次循環(huán),取源數(shù)據(jù)第’,rs_startrow,’行至’,i*N,’行’,’寫入到第’,startRow,’行’) print(’第’,str(i),’次寫入數(shù)據(jù)為:’,df_fetch_data[rs_startrow:i*N]) # 重新指定源數(shù)據(jù)的讀取起始行 rs_startrow =i * N i+=1 # 寫入文件的開始行數(shù) # 當(dāng)沒有做任何循環(huán)時,仍然從第一行開始寫入 if is_while == 0: startRow = startRow else: startRow+=N df_fetch_data[’batch’] = ’batch’+str(i) print(’第{0}次讀取數(shù)據(jù),從第{1}行開始,寫入到第{2}行!’.format(str(i), str(rs_startrow), str(startRow))) print(’第’,str(i),’寫入數(shù)據(jù)為:’,df_fetch_data[rs_startrow:i*N]) df_fetch_data[rs_startrow:i*N].to_excel(writer, header=isHeader, index=False, startrow=startRow) # 注: 這里一定要saver()將數(shù)據(jù)從緩存寫入磁盤!!!!!!!!!!!!!!!!!!!!!1 writer.save() start_time=datetime.datetime.now() # 導(dǎo)出結(jié)構(gòu)相同的多個表到同一樣excel def exportToExcel(self, **args): for sourceTB in args[’sourceTB’]: arc_dict = dict(sourceTB = sourceTB,path=args[’path’],startRow=args[’startRow’],isHeader=args[’isHeader’],batch=args[’batch’] ) print(’n當(dāng)前導(dǎo)出的數(shù)據(jù)表為:%s’ %(sourceTB)) self.writeToExcel(**arc_dict) return ’success’ start_time=datetime.datetime.now() if __name__ == '__main__': ms = MSSQL(host='localhost',user='test',pwd='test',db='db_jun') args = dict( sourceTB = [’tb2’, ’tb1’],# 待導(dǎo)出的表 path=’D:myPCPython’,# 導(dǎo)出到指定路徑 startRow=1,#設(shè)定寫入文件的首行,第2行為數(shù)據(jù)首行 isHeader=False,# 是否包含源數(shù)據(jù)的標(biāo)題 batch=5 ) # 導(dǎo)出多個文件 ms.exportToExcel(**args)

以上這篇使用Python實(shí)現(xiàn)將多表分批次從數(shù)據(jù)庫導(dǎo)出到Excel就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: python
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品99久久免费| 日韩欧美少妇| 在线精品视频一区| 免费黄网站欧美| 久久高清国产| 视频一区在线播放| 国产一区白浆| 亚洲一区二区三区四区电影| 久久国产99| 中文在线日韩| 欧美啪啪一区| 国产精品永久| 国精品产品一区| 神马久久午夜| 国产精品麻豆久久| 欧美 日韩 国产精品免费观看| 一本色道久久精品| 亚洲毛片一区| 国产精品久久亚洲不卡| 精品精品久久| 999精品色在线播放| 久久国产福利| 国产欧美日韩影院| 神马久久午夜| 爽爽淫人综合网网站| 日本v片在线高清不卡在线观看| 国产乱人伦丫前精品视频| 精品一区二区三区免费看| 亚洲www免费| 一区二区亚洲精品| 日韩欧美中文字幕一区二区三区| 国产激情久久| 国产亚洲一区二区手机在线观看 | 日本麻豆一区二区三区视频| 国产精品亚洲综合久久| 黄色aa久久| 久久夜色精品| 开心激情综合| 午夜久久美女| 欧美亚洲福利| 成人羞羞在线观看网站| 亚洲精品第一| 精品国产一级| 亚洲综合日韩| 精品淫伦v久久水蜜桃| 国产精品7m凸凹视频分类| 日韩av中文在线观看| 鲁鲁在线中文| 亚洲欧美在线专区| 国产成人精品999在线观看| 中文精品视频| 麻豆免费精品视频| 999在线观看精品免费不卡网站| 日韩不卡免费视频| 丝袜美腿一区| 97久久中文字幕| 久久精品99久久无色码中文字幕| 美女久久网站| 超级白嫩亚洲国产第一| 亚洲午夜免费| 亚洲综合在线电影| 久久国产三级精品| 九一成人免费视频| 欧美激情久久久久久久久久久| 国产中文一区| 免费在线播放第一区高清av| 黄色av一区| 国产aⅴ精品一区二区三区久久| 免费人成在线不卡| 亚洲性色av| 国产精品一区免费在线| 在线一区电影| 久久影视三级福利片| 久久福利毛片| 亚洲www啪成人一区二区| 久久国内精品自在自线400部| 黑丝一区二区三区| 波多野结衣久久精品| 国产日韩一区二区三免费高清| 亚洲色诱最新| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 国产一级成人av| 不卡在线一区二区| 精品视频久久| 91麻豆精品激情在线观看最新| 婷婷激情图片久久| 久久中文精品| 午夜天堂精品久久久久| 婷婷综合五月| 久久影视一区| 国产一区调教| 麻豆成人av在线| 青青草国产精品亚洲专区无| 男女男精品视频网| 最新日韩av| 偷拍欧美精品| 亚洲91久久| 麻豆mv在线观看| 国产一区2区在线观看| 国产精品久久国产愉拍| 日韩精品第二页| 91久久久精品国产| 久久一区二区三区电影| 日韩免费高清| 日本蜜桃在线观看视频| 国产精品精品| 国产中文字幕一区二区三区| 狂野欧美性猛交xxxx| 久久精品三级| 粉嫩av一区二区三区四区五区| 久久99久久久精品欧美| 国产精品久久久一区二区| 久久国内精品| 免费在线欧美黄色| 精品三级在线| 黄在线观看免费网站ktv| 久久99精品久久久野外观看| 国产日产精品一区二区三区四区的观看方式| 亚洲一区二区三区久久久| 午夜在线一区二区| 噜噜噜躁狠狠躁狠狠精品视频| 亚洲欧美日韩国产综合精品二区 | 国产精品一级| 美女高潮久久久| 久久久免费人体| 欧美激情国产在线| 国产精品第一| 精品视频91| 在线看片福利| 在线日韩欧美| 欧美日韩国产探花| 日本欧美在线看| 日韩高清一区二区| 久久国产麻豆精品| 国产精品v亚洲精品v日韩精品| 久久三级中文| 中文字幕在线高清| 亚洲一本视频| 香蕉视频成人在线观看| 日本亚洲视频| 国产欧美丝祙| 国产69精品久久| 亚洲h色精品| 三级欧美在线一区| 91精品麻豆| 狠狠久久伊人| 欧美日韩国产免费观看视频| 久久国产精品亚洲77777| 日韩成人午夜精品| 国产精品99在线观看| 亚洲一级高清| 天堂va在线高清一区| 麻豆视频观看网址久久| 91精品亚洲| 亚洲tv在线| 福利一区和二区| 最新日韩欧美| 日产欧产美韩系列久久99| 久久亚洲资源中文字| 在线日韩av| 日韩在线网址| 三上亚洲一区二区| 亚洲视频www| 国产欧美日韩一区二区三区四区| 福利一区二区三区视频在线观看| 婷婷丁香综合| 青青草国产精品亚洲专区无| 韩国久久久久久| 亚洲免费中文| 久久久久97| 久久av在线| 丰满少妇一区| 欧美一区二区三区高清视频| 婷婷亚洲成人| 新版的欧美在线视频| 美日韩精品视频| 日韩av在线中文字幕| 国产精品试看| 国产精品中文字幕亚洲欧美| 成人免费电影网址| 日韩美女国产精品| 激情不卡一区二区三区视频在线| 91精品国产自产在线丝袜啪| 亚洲精品午夜av福利久久蜜桃| 亚洲伊人影院| 国产精品hd| 欧美色图国产精品| 99热免费精品| 久久免费视频66| 石原莉奈在线亚洲二区| 精品一区二区三区亚洲| 91久久黄色| 久久一区欧美| 蜜臀精品一区二区三区在线观看| 久久精品国产免费| 影音国产精品| 97精品国产| 欧美日韩在线精品一区二区三区激情综合 | 国产精品外国| 精品午夜久久|