-
-
Notifications
You must be signed in to change notification settings - Fork 242
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Images & formatting lost after writing to existing file #275
Comments
Have you tried writing to a new file? Does that work? |
@zdavatz Could you be more specific? It looks like you're suggesting writing my data to a new file instead of the tmp copy of the template, which would defeat the purpose of what I am trying to do. It is the existing images and styling in the template that are getting lost when I write to unrelated cells/sheets. |
which software created the original file you are trying to edit with the Spreadsheet Gem? |
The original template file was made manually by a human. The file that I am parsing in Spreadsheet and writing to is a Tempfile that I wrote the original file into (variable |
Was the Original File created by Openoffice or MS Office? On Mac or on Windows? Any chances of seeing the original file? |
I'm not able to share the original file unfortunately. And I do not know the circumstances of its original creation. My client has many template files like this that have existed for a long time. If there are ways they could re-create the templates for a better chance of success, then I am all ears. |
I would try to created the templates with Ruby spreadsheet from the start, then modify the file and then save as a new file. Sometimes the software creating the original files adds binary information, that Ruby Spreadsheet does not add, then all fails. So if you can, I would go the whole way with Ruby Spreadsheet. |
Ok that could explain it, but I'm still not understanding why this works perfectly:
But this destroys the binary info:
What am I missing? |
Can we try to reproduce this with a sample file of yours? |
I was able to reproduce with this template file: And here is the resulting export file with "hello" written to it. The image on the second sheet has been lost. |
Ok, so the original file was created by Miguel Rocafort. Which software did he use to create the file? Which OS? Did he use the spreadsheet gem to the create the file template.xls? |
Not sure who that is, but the spreadsheet gem was not used to create the template file. These templates are created by users -- not with this gem, so using the gem to produce test templates does not match my use case. I used this chrome extension to create the above test file: https://chromewebstore.google.com/detail/xls-editor/iobjaooppmgjlgomfpaohhncpfjpigaf From what I understood you were looking to see the behavior reproduced, and the above test file matches what I'm seeing with my users' files. |
It’s looking like this gem may not be the right fit for my case. I wish I had a deeper understanding (and more time) so I could contribute to researching, but realistically at this point I just need a workaround. If I can get my client on board with converting template files to xlsx, then I can use the RubyXL gem with the same logic, and the file remains intact. Thanks so much for your time and effort! I’m happy to keep discussing/providing context if its of any further value. |
I have the following two models in a Rails app:
My goal is to make a copy of the template file from ModelA, write data to that copy, and save it to the export file on ModelB.
My ModelA template file is an xls attachment with 4 worksheets. The first worksheet has a styled header row. I am writing only to the columns under those headers. The other worksheets in the file have images in them.
The result of my code is a copy of the file with the same worksheets with my data written to the first sheet as-expected--except all images are missing and some of the header formatting is lost (for example, text alignment is lost, but background color is not).
If I comment out the call to
write_to_sheet(sheet)
in thebuild_and_attach_export
method, then I end up with a perfect copy of the original file saved asexport_file
. However any attempt to write to any cell in the sheet results in the lost images and formatting.Does anyone have any insight into why this might be happening?
The text was updated successfully, but these errors were encountered: