如何用phpspreadsheet來切割excel大檔案(附代碼)

來源:互聯網
上載者:User
這篇文章給大家介紹的內容是關於如何用phpspreadsheet來切割excel大檔案(附代碼),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所協助。

背景:

利用phpspreadsheet可以輕鬆的解析excel檔案,但是phpspreadsheet的記憶體消耗也是比較大的,我試過解析將近5M的純文字excel記憶體使用量量就會超過php預設的最大記憶體128M。
當然這可以用調節記憶體大小的方法來解決,但是在並發量大的時候就比較危險了。所以今天介紹下第二種方法,利用phpspreadsheet對excel檔案進行切割,這是個拿時間換空間的方法所以一般對時效性要求低的需求可以使用。

方法:

先放個phpspreadsheet官網提供的一個功能readCell,我們就可以利用這個功能來進行切割。

首先對excel檔案進行預讀,主要是擷取所有的工作表以及工作表下面的資料行數,這個階段readCell方法一直返回的都是false,我們只需要記錄readCell進來的工作表及資料行數。

然後就是對擷取到的記錄進行分析,確定每部分資料需要裝多少行原始excel的資料,需要注意的是為了避免內容混淆,不要講兩個工作表的內容切到一起。

最後就是迴圈分析的資料和再次利用readCell擷取每部分資料,注意每次讀取檔案後都要利用disconnectWorksheets方法清理phpspreadsheet的記憶體。

經過我自己的測試發現,利用該方法解析5M的excel檔案,平均只需要21M的記憶體就可以搞定!

代碼:

  https://github.com/wangyelou/Tools/tree/master/CutExcel

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.