8

I am currently working on jquery datatables. And now am facing a small problem i want to customize the exported data. ie, i want to customize the expoerted sheet .And i succesfully customized the print button with the documentation from datatables page https://datatables.net/extensions/buttons/examples/print/customisation.html

but am unable to customize export to excel/csv/pdf

i would i like to have exported data like below image expected exported sheet image

and currently my exported sheet is like currect sheet image

and code below is my current state

      buttons: [

            {
                extend: 'print',
                exportOptions: {
                    columns: [1, 2, 3, 4, 6, 7, 13]
                },
                customize: function (win) {
                    $(win.document.body)
                        .css('font-size', '10pt')
                        .prepend(
                            '<img src="" style="position:absolute; top:0; left:0;" />'
                        );

                    $(win.document.body).find('table')
                        .addClass('compact')
                        .css('font-size', 'inherit');
                },



            },
            {
                extend: "collection",
                text: "Save",
                buttons: [
                    {
                        extend: 'csv',
                        exportOptions: {
                            columns: [1, 2, 3, 4, 6, 7, 13]
                        },

                    },
                    {
                        extend: 'excel',
                        exportOptions: {
                            columns: [1, 2, 3, 4, 6, 7, 13]
                        },

                    },
                    {
                        extend: 'pdf',
                        exportOptions: {
                            columns: [1, 2, 3, 4, 6, 7, 13]
                        },
                        customize: function (doc) {
                            doc.content.splice(1, 0, {
                                margin: [0, 0, 0, 12],
                                alignment: 'center',
                                image: ''
                            });
                        }


                    },
                     {
                         extend: 'copy',
                         exportOptions: {
                             columns: [1, 2, 3, 4, 6, 7, 13]
                         },
                     }

                ]


            }
        ],

could anybody help me to acheive this

0

1 Answer 1

6

For the excel, this function will add a new rows at the top of document:

customize: function (xlsx) {
                var sheet = xlsx.xl.worksheets['sheet1.xml'];
                var numrows = 3;
                var clR = $('row', sheet);

                //update Row
                clR.each(function () {
                    var attr = $(this).attr('r');
                    var ind = parseInt(attr);
                    ind = ind + numrows;
                    $(this).attr("r",ind);
                });

                // Create row before data
                $('row c ', sheet).each(function () {
                    var attr = $(this).attr('r');
                    var pre = attr.substring(0, 1);
                    var ind = parseInt(attr.substring(1, attr.length));
                    ind = ind + numrows;
                    $(this).attr("r", pre + ind);
                });

                function Addrow(index,data) {
                    msg='<row r="'+index+'">'
                    for(i=0;i<data.length;i++){
                        var key=data[i].key;
                        var value=data[i].value;
                        msg += '<c t="inlineStr" r="' + key + index + '">';
                        msg += '<is>';
                        msg +=  '<t>'+value+'</t>';
                        msg+=  '</is>';
                        msg+='</c>';
                    }
                    msg += '</row>';
                    return msg;
                }


                //insert
                var r1 = Addrow(1, [{ key: 'A', value: '' }, { key: 'B', value: '' }]);
                var r2 = Addrow(2, [{ key: 'A', value: '' }, { key: 'B', value: '' }]);
                var r3 = Addrow(3, [{ key: 'A', value: '' }, { key: 'B', value: '' }]);

                sheet.childNodes[0].childNodes[1].innerHTML = r1 + r2+ r3+ sheet.childNodes[0].childNodes[1].innerHTML;
            }

For CSV:

customize: function(doc){
                return "Your text" + doc;
            }

For the others exports you will need to put a message parameter like this:

{
            extend: 'print',
            message: "Your text"
        },
Sign up to request clarification or add additional context in comments.

3 Comments

thanks ,but this post is about 7 month old and i tried another method .any way hope this will help others
How to add title in excel coloumn with bold style text and merge cell?
What about the PDF? How can we add the custom row at the very end of the table while exporting in PDF format?

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.