Large workbook, one sheet to edit

Topics: User Forum
Apr 26, 2012 at 7:34 PM

I have a workbook with many sheets, only one of which I need to alter the values in a few cells. Is it possible to do this without loading the entire workbook? The way I've tried seems to want to load everything and that causes memory and speed issues (seems a common issue here). I've resorted to using a two Excel files, one with the sheet in question and the other referencing the first. 

Apr 28, 2012 at 10:05 AM

PHPExcel is not a file editor: it always reads the entire file (that's simply how it works). Have you tried caching or any of the other memory saving techniques: while there will always be a trade off between memory and performance, that's the best compromise option?

Apr 29, 2012 at 1:12 PM

That's a shame. If I were to start a project like PHPExcel that would be my first and highest priority goal because without it you're relegated to relatively small files.

I've tried caching but that just increases the time it takes to execute to well beyond the 30 seconds allocated in php.ini, and this really needs to be quick. I think 2 or 3 seconds might be acceptable, but that time out happens when running on a 2011 Macbook Pro (2.2Ghz i7) with an SSD! The system this will eventually go on is much slower.

May 2, 2012 at 7:59 AM
Edit_A_Sheet wrote:

That's a shame. If I were to start a project like PHPExcel that would be my first and highest priority goal because without it you're relegated to relatively small files.

The developers of PHPExcel apologise for not having the foresight to realise that they should have been developing a file editor, and sincerely regret that they've wasted 6+ years of their lives. We humbly request permission to commit hara kiri for not having your vision: feel free to continue our work when we're dead by writing your own Excel read/writer which, no doubt, will be the perfect combination of speed and efficiency... we look forward to testing it from the afterlife.

Working with large workbooks is best done as a background process, and not within the scope of a browser request.

May 2, 2012 at 8:56 AM

what he said!


You have some nerve, first asking for help, and then when the answer is not satisfactory, start ranting. if you don't like the library, use something else, or even better, write your own. Good luck with that!

May 2, 2012 at 12:51 PM

Seriously??? You think it takes some significant foresight to see that it might be important to edit a single spreadsheet out of a much larger project? The web is littered with people trying to do this very thing and being told to try PHPExcel, only to report its failure. I cannot believe you haven't had many requests for this ability since PHPExcel's inception. If you don't want to add it, fine, but don't expect everyone to be happy with the product. They're not.

Personally, I don't care. I've got my project working, although in a different manner than I wanted. If I ever have to write to Excel files again I probably will roll my own. I won't have the ability to add or alter conditional styles or graphics, but I will be able to alter values/formulas in individual sheets. Like it or not, that is more important.

Now, since it's apparently verboten to offer even the slightest criticism of your glorious product I'll say my final goodbye here and unsubscribe.

May 2, 2012 at 9:08 PM


The Open Source world is filled with dozens of failed PHP libraries for reading or writing Excel, to some degree or other. PHPExcel is the only such project that has survived.... and none were designed for editing Excel files... indeed, I can only think of one alternative library that is still (partly) supported and capable of reading and writing, but that only works with BIFF .xls files and requires a commercial (and Linux only) library.

At the time when PHPExcel was started, it was intended as a simple library for reading and/or writing small workbooks within a single library. There was no alternative in a single library. Nor has anybody developed any alternative reader/writer that supports multiple formats in the intervening years. In fact, while many developers have released libraries that can read or write Excel files in one format or another in the intervening years, only one of those is still active. Over that time PHPExcel has grown in functionality, supporting more and more features of Excel (and other spreadsheet formats) with each release, and is now being used for working with much larger workbooks than was ever originally intended; but it is still an "in memory" library.

The structure of Excel files of any format is not conducive to reading small parts or a workbook, editing and rewriting. Cell data might be distributed across several "files" (string content or formulae for example are spread across at least two different files, sometimes more depending on the actual data) while formatting information might be distributed across half a dozen files, given the inheritence of row and/or column formatting, default worksheet styling, etc. I'm not aware of any readers/writers for any language (including Microsoft's own offerings) that don't read the entirety of the workbook. The difference is that PHPExcel is restricted by available PHP memory limits.

While we are more than happy to introduce new features that are requested, or accept constructive criticism that offers alternative ways of working, your post came across merely as criticism... if it had been you writing it, you'd have done it right first time and with a foresight that we didn't show. You're telling us that we were a bunch of short-sighted incompetents who lack your vision. Having spent much of my free time in the last 6 or more years developing a library that is freely available for anybody to use, I find that insulting. I'm probably more aware of the shortcomings of PHPExcel (and of its in-memory model) than most, and have invested a lot of time and effort in trying to overcome those problems.

Can we bypass PHP's memory limitations without a high cost in performance? Yes we can, but only with a complete rewrite from scratch, and that will take many months or work, and won't be written in PHP. Nor will it be PHPExcel, but a new library. It's on my to-do list alongside a number of other OS projects that I assist with, and alonside a few new projects that I'm planning.

Because PHPExcel can't handle reading and writing the largest of workbooks in seconds, there's obviously a demand for an alternative. PHPExcel's permissive license allows you to fork the project if you wish: there is nothing to stop you writing your own Excel reader/writer based on PHPExcel, or writing it from scratch yourself; and if that's what you want to do, I wish you luck.