91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2021-03-02 13:57:20 來源:億速云 閱讀:410 作者:小新 欄目:開發技術

小編給大家分享一下如何使用Python快速打開一個百萬行級別的超大Excel文件,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

有同學求助說,當他試圖打開一個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']
id
100
耗時0.404秒鐘
>>> read_xlsx(False)
['Sheet']
id
100
耗時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 99
1  2 90 100 95 99
2  3 90 100 95 99
3  4 90 100 95 99
4  5 90 100 95 99
       id 語文  數學 英語 物理
999995  999996 90 100 95 99
999996  999997 90 100 95 99
999997  999998 90 100 95 99
999998  999999 90 100 95 99
999999 1000000 90 100 95 99
耗時81.369秒鐘

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

看完了這篇文章,相信你對“如何使用Python快速打開一個百萬行級別的超大Excel文件”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

理塘县| 铁岭县| 元朗区| 丘北县| 平利县| 许昌县| 芦溪县| 宁河县| 深水埗区| 丰都县| 固阳县| 西宁市| 盈江县| 宿松县| 红河县| 页游| 左贡县| 景谷| 盱眙县| 盐亭县| 丽江市| 曲沃县| 肇源县| 闽清县| 汨罗市| 太康县| 广东省| 三门峡市| 大英县| 新丰县| 信丰县| 蕲春县| 旌德县| 澜沧| 济源市| 罗源县| 阿巴嘎旗| 航空| 大冶市| 日土县| 赣榆县|