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
and currently my exported sheet is like
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
Try simple code, to convert DataTable to excel file as csv: var lines = new List<string>(); string[] columnNames = dataTable. Columns . Cast<DataColumn>() .
You need to simply add below javascript cdn to add export button in datatable. Add below javascript code in your script tag. $(document). ready(function() { $('#export_example').
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"
},
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With