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

溫馨提示×

溫馨提示×

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

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

如何解決python 使用openpyxl讀寫大文件的問題

發布時間:2021-03-15 10:49:35 來源:億速云 閱讀:1356 作者:TREX 欄目:開發技術

這篇文章主要講解了“如何解決python 使用openpyxl讀寫大文件的問題”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何解決python 使用openpyxl讀寫大文件的問題”吧!

由于需要處理xlsx類型的文件,我使用了openpyxl來處理,然而文件比較大,大約有60多MB。讀文件的時候雖然慢了一點,但還是能夠讀出來,但是當我想寫入時卻報錯了。

如何解決python 使用openpyxl讀寫大文件的問題

顯示設備沒有多余的空間,百度了一下,發現有不少關于openpyxl讀寫大文件的問題。總結來看,解決方案主要有以下兩種,當然,我兩種都用上了。

手動釋放內存

del wb, ws
gc.collect()

這一招還算有用,在讀完文件后可以看到內存占用明顯下降了一點。

安裝lxml

使用命令·pip install lxml安裝依賴

這個依賴并非必須安裝的依賴,但是可以使openpyxl流式處理數據。

總之使用了以上兩種方案后,終于可以成功處理數據了。

補充:openpyxl讀取大文件的若干問題

需要編寫一個EXCEL文件對比工具

excel文件通常8MB,300張左右的表,每張表實際范圍為ZZ500.

使用openpyxl對表格進行遍歷,完成兩個表之間的對比,找出公式不相同的單元格編程中遇到若干問題

1、讀取時報錯,錯誤代碼忘記了,原因是通過數組的方式讀取了一個不存在的數值

如 SS['AA'],這個數值沒有定義,因此報錯(PHP直接返回空值),使用SS.get('AA',null)進行修改

D:\Python34\Lib\site-packages\openpyxl\reader\style.py

164: format_code = builtin_formats.get(numFmtId,'General')

2、讀取時內存占用過大

基本就是內存占用了2G以上以后,程序就不動了,原因是某些表格的表格范圍識別的非常大,最大可為ZZ65535

通過研究,代碼進行了如下修改

1:使用X64版本,X64版本在運行時,可以運行4G以內內存占用的程序,比2G大一倍,能夠完成大部分表格的讀取,如ZZ5000,但是遇到ZZ65535范圍的表格,內存占用達到了4G+,也會導致程序停止運行.

2:限制最大單元格遍歷范圍,最大限制為ZZ5000,能夠有效降低內存占用

3:定時重新讀取EXCEL文件(如每對比30張表),釋放內存,(Python內存釋放真的很痛苦,全部是指針引用,A=B,DEL A;是不會釋放空間的,要DEL B才行).

4:雖然openpyxl讀取文件時有個只讀模式(性能模式),但是速度實在是太慢了.

通過代碼修改,現在完成文件對比所用的內存通常在2G以內

感謝各位的閱讀,以上就是“如何解決python 使用openpyxl讀寫大文件的問題”的內容了,經過本文的學習后,相信大家對如何解決python 使用openpyxl讀寫大文件的問題這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

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

AI

邵阳县| 孝感市| 乌海市| 陆丰市| 饶河县| 开化县| 昌图县| 视频| 甘谷县| 岐山县| 昌宁县| 博兴县| 黎城县| 思南县| 五大连池市| 西畴县| 航空| 德格县| 陕西省| 安徽省| 古蔺县| 津南区| 讷河市| 通河县| 红安县| 微山县| 随州市| 通山县| 灵宝市| 即墨市| 潍坊市| 大田县| 长丰县| 新晃| 肥乡县| 桃园县| 镇坪县| 扶沟县| 南召县| 藁城市| 灵石县|