How to Keep Specific Row at Bottom When Exporting Table to Excel?
How to Keep Specific Row at Bottom When Exporting Table to Excel?
data:image/s3,"s3://crabby-images/caeea/caeea5e018e9e08759ac17ca476c2c57f8499ad1" alt="Mansi_"
Hello,
I’m currently working on a project where I have a data table displayed on the screen. I’ve implemented some JavaScript code to keep the grand total row fixed at the bottom of the table, ensuring it always appears as the last row when viewed on the screen.
However, I’ve encountered an issue when exporting this data to Excel. The grand total row ends up being placed in the middle of the exported file instead of at the bottom, which is not the desired outcome.
Here’s a screenshot of how the data looks in the table and how it appears in the exported Excel file:
Data shown on my table:
Exported data in excel:
Is there a way to export the data to Excel so that it maintains the same layout as shown in the table, with the grand total row fixed at the bottom? Any guidance or code snippets would be greatly appreciated!
Thank you in advance for your help!
Answers
Is your "Grand Total" a row in the table's footer? If it is, it should be exported at the bottom of the table. If that isn't working for you, please link to a test case showing the issue.
Allan
It looks like you are using jQuery or Javascript methods to move the row to the bottom of the table, is this correct? If yes then that means Datatables doesn't know about the move as it has the rows in alphabetical order. Instead use the Absolute Position sorting plugin to have Datatable sort that row to the bottm. Then it should export at the bottom.
If this doesn't help then please provide the test case Allan asked for.
https://datatables.net/manual/tech-notes/10#How-to-provide-a-test-case
Kevin
yes i have writen js code to move the row at bottom and then as allan said using footer but the issue is not resolved it is showing correctly in table but in excel it is based on sorted data like this below code:
Table:
Excel:
please help me to find where i am doing wrong?
Your Grand total data is still in the table body data. You are using
drawCallback
to remove it from the display, so yes, I would expect it to still be shown in the Excel output since it is part of the data.It needs to be removed from the data - it is not a regular row.
You can either include the information in a special property of the JSON reply - perhaps
footerData
, and then check for that in your callbacks (initComplete
in this case) and write it into the footer. Or you can calculate the values client-side.Allan