婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 使用Python快速打開一個百萬行級別的超大Excel文件的方法

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

熱門標簽:舉辦過冬奧會的城市地圖標注 螳螂科技外呼系統怎么用 正安縣地圖標注app 400電話申請資格 地圖地圖標注有嘆號 遼寧智能外呼系統需要多少錢 阿里電話機器人對話 qt百度地圖標注 電銷機器人系統廠家鄭州

知乎上有同學求助說,當他試圖打開一個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文件的方法的文章就介紹到這了,更多相關python打開excel文件內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 如何用python合并多個excel文件
  • python合并多個excel文件的示例
  • 使用python將多個excel文件合并到同一個文件的方法
  • 使用Python橫向合并excel文件的實例
  • Python批量合并有合并單元格的Excel文件詳解
  • Python將多個excel文件合并為一個文件
  • 淺談Python xlwings 讀取Excel文件的正確姿勢
  • Python3利用openpyxl讀寫Excel文件的方法實例
  • 基于Python的接口自動化讀寫excel文件的方法
  • python基于openpyxl生成excel文件
  • Python xlrd/xlwt 創建excel文件及常用操作
  • 教你用Python代碼實現合并excel文件

標簽:昭通 合肥 淘寶好評回訪 濟源 隨州 興安盟 阜新 信陽

巨人網絡通訊聲明:本文標題《使用Python快速打開一個百萬行級別的超大Excel文件的方法》,本文關鍵詞  使用,Python,快速,打開,一個,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《使用Python快速打開一個百萬行級別的超大Excel文件的方法》相關的同類信息!
  • 本頁收集關于使用Python快速打開一個百萬行級別的超大Excel文件的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 和林格尔县| 海宁市| 仙桃市| 维西| 鄂伦春自治旗| 武夷山市| 当雄县| 于都县| 武安市| 芷江| 梨树县| 北票市| 台湾省| 尉犁县| 富民县| 舒城县| 蕲春县| 化德县| 澄城县| 吉木萨尔县| 师宗县| 宜兰县| 株洲市| 博野县| 洛浦县| 涞水县| 大城县| 克东县| 肇州县| 新田县| 旌德县| 安吉县| 长春市| 墨玉县| 吉木乃县| 积石山| 松江区| 洪泽县| 探索| 长兴县| 鸡西市|