国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

使用Python快速打開一個百萬行級別的超大Excel文件的方法

瀏覽:6日期:2022-06-27 15:54:17

知乎上有同學求助說,當他試圖打開一個20M左右的excel文件時,無論是使用pandas的read_excel,還是直接使用xlrd或者openpyxl模塊,速度都慢到無法忍受的程度,耗時大約1分鐘左右。

真的會這樣嗎?第一感覺是,這位同學在使用openpyxl模塊時沒有設置只讀模式。為便于測試,先用下面的代碼生成一個一百萬行數據的excel文件。

>>> from openpyxl import Workbook>>> wb = Workbook()>>> sh = wb.active>>> sh.append([’id’, ’語文’, ’數學’, ’英語’, ’物理’])>>> for i in range(1000000): # 寫入100萬行數據sh.append([i+1, 90, 100, 95, 99])>>> wb.save(r’d:bigxlsx.xlsx’)>>> import os>>> os.path.getsize(r’d:bigxlsx.xlsx’) # 文件大小:20M字節20230528

接下來定義了一個使用openpyxl模塊打開文件的函數,分別考察關閉和開啟只讀模式的時間消耗。

>>> from openpyxl import load_workbook>>> import time>>> def read_xlsx(read_only):t0 = time.time()wb = load_workbook(r’d:bigxlsx.xlsx’, read_only=read_only)t1 = time.time()print(wb.sheetnames)print(sh.cell(row=1, column=1).value)print(sh.cell(row=100, column=3).value)print(’耗時%0.3f秒鐘’%(t1-t0))>>> read_xlsx(True)[’Sheet’]id100耗時0.404秒鐘>>> read_xlsx(False)[’Sheet’]id100耗時67.817秒鐘

運行測試,果然,不開啟只讀的話,真的需要1分多鐘,而使用只讀模式的話,則僅需0.4秒鐘。

不過,也別高興得太早,openpyxl模塊并沒有提供像pandas.read_excel()那樣把全部數據讀入一個數據結構的功能,只能定位到行、列或格子以后再讀取數據。要想使用openpyxl模塊把全部數據讀入到數組或DataFrame中,需要遍歷所有的行和列,這仍然是一個非常耗時的操作。

那么,pandas.read_excel()是否也支持只讀模式呢?遺憾的是,read_excel()并沒有類似read_only這樣的參數。盡管read_excel()可以接受文件路徑、文件對象、類文件對象,甚至是二進制數據,但即使將文件內容傳入,read_excel()解析這100萬行數據仍然需要大約80秒鐘。下面的代碼驗證了這一點。

>>> import pandas as pd>>> def read_excel_by_pandas():with open(r’d:bigxlsx.xlsx’, ’rb’) as fp:content = fp.read()t0 = time.time()df = pd.read_excel(content, engine=’openpyxl’)t1 = time.time()print(df.head())print(df.tail())print(’耗時%0.3f秒鐘’%(t1-t0))>>> read_excel_by_pandas() id 語文 數學 英語 物理0 1 90 100 95 991 2 90 100 95 992 3 90 100 95 993 4 90 100 95 994 5 90 100 95 99 id 語文 數學 英語 物理999995 999996 90 100 95 99999996 999997 90 100 95 99999997 999998 90 100 95 99999998 999999 90 100 95 99999999 1000000 90 100 95 99耗時81.369秒鐘

結論:處理超大的Excel文件時,使用openpyxl模塊的只讀模式,可以快速打開并取得指定格子的數據,但不要嘗試將全部數據讀入到自己定義的數據結構中,這將花費漫長的時間。對此,pandas也無能為力。

到此這篇關于使用Python快速打開一個百萬行級別的超大Excel文件的方法的文章就介紹到這了,更多相關python打開excel文件內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: python
相關文章:
主站蜘蛛池模板: 在线a毛片免费视频观看 | 97精品福利视频在线 | 国产成人午夜精品免费视频 | 久久亚洲精品中文字幕亚瑟 | 热99re久久精品这里都是免费 | 亚洲午夜综合网 | 欧美视频在线观在线看 | 日韩a一级欧美一级在线播放 | 极品丝袜高跟91白沙发在线 | 日韩精品亚洲专区在线观看 | 99爱视频在线观看 | 国产极品喷水视频jk制服 | 99精品视频在线在线视频观看 | 亚洲国产精品综合欧美 | 一级a做爰片欧欧美毛片4 | 日韩欧美在线视频一区二区 | 草草视频在线观看最新 | 国产在线精品一区二区 | 2022国产精品手机在线观看 | 国产不卡一区二区三区免费视 | 国产午夜亚洲精品国产 | 免费视频观看在线www日本 | 三级免费网站 | 步兵社区在线观看 | 欧美成人性色xxxx视频 | 日韩美女毛片 | 久在线观看视频 | 在线视频一区二区三区四区 | 一级色黄 | 日韩国产精品99久久久久久 | 一级片免费网址 | 亚洲性爰视频 | 一级一片免费播放 | 亚洲gogo人体大胆西西安徽 | 九九九在线视频 | a色在线| 欧美成人午夜片一一在线观看 | 女人张开腿让男人桶视频免费大全 | 视频网18免费 | 免费在线一区二区三区 | 国产一级毛片大陆 |