-
Notifications
You must be signed in to change notification settings - Fork 79
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
Exporting and formatting of table data to Excel #385
Comments
I was going to make an Excel export example a while back but just didn't have time. That one was going to use SheetJS I believe. I've heard of ExcelJS and I know there are a bunch of other competing libraries, but good to know that MUI chose ExcelJS. Here's the last issue where someone did this with SheetJS, that you might find useful: #291 So we'd start with adding a similar example to the docs using either of these. For a built-in feature, we'd need to evaluate the libraries more closely to see which is the best to pull in, or if it's even worth pulling them in. External libraries are usually challenging because of the added download size (especially for an optional feature) and maintenance cost, keeping up with security fixes, and etc. Unlike in JavaScript, it's not as easy to conditionally bring in code only when you use it, but we could probably get close by having ExcelJS/SheetJS be a separate file that gets conditionally included as a widget dependency somehow. |
Thank you for replying @glin . It is true that there are several libraries that can be used but it all depends on the goal you have in mind. In my case I need not only to export to excel but also for the file to have some formatting (or style) and this can be easily achieved with exceljs. I don't know SheetJS in terms of functionality so you will have to evaluate that part yourself. Here's an example... Right now the code I started from is this one: [Shiny App]
[export_excel.js]
What I have done is to use as data input for the javascript file the output data from reactable (a TSV file is generated using the API) and this is processed and transformed into the output of the exceljs library. I have also added some lines of code so you can see that it is easy to format the excel (change the font-type to 'Arial' and font-size '12'). I hope this helps you to make a decision. Thanks for taking our suggestions into account, good work. Best regards, |
Greg, do you plan to incorporate new export formats directly from Reactable apart from CSV? It would be interesting to have an option to download and export the table data (filtered or raw) to excel. I have been researching and there are libraries in react like MUI that use the exceljs package [link] to generate a formatted excel file from the table data. It would be great to have this option in Reactable.
I leave you a link on the mui website where they give more details of the integration:
https://mui.com/x/react-data-grid/export/#excel-export
Reactable is already brilliant and necessary in my day to day work but it would be very interesting to have the option to export to Excel. What do you think?.
Thank you very much for all your work.
Best regards,
Sergio
The text was updated successfully, but these errors were encountered: