React convert JSON to CSV using JSONToCSVConvertor
function. Suppose you have a table (GUI react table tool) and you want to export it into excel, then this function will come very handy. Since excel supports CSV, so you can easily open the file into any excel software.
const JSONToCSVConvertor = (JSONData, ReportTitle, ShowLabel) => {
//If JSONData is not an object then JSON.parse will parse the JSON string in an Object
var arrData =
typeof JSONData !== "object" ? JSON.parse(JSONData) : JSONData;
var CSV = "";
//This condition will generate the Label/Header
if (ShowLabel) {
var row = "";
//This loop will extract the label from 1st index of on array
for (var index in arrData[0]) {
//Now convert each value to string and comma-seprated
row += index + ",";
}
row = row.slice(0, -1);
//append Label row with line break
CSV += row + "\r\n";
}
//1st loop is to extract each row
for (var i = 0; i < arrData.length; i++) {
var row = "";
//2nd loop will extract each column and convert it in string comma-seprated
for (var index in arrData[i]) {
row += '"' + arrData[i][index] + '",';
}
row.slice(0, row.length - 1);
//add a line break after each row
CSV += row + "\r\n";
}
if (CSV === "") {
alert("Invalid data");
return;
}
//Generate a file name
var fileName = "MyReport_";
//this will remove the blank-spaces from the title and replace it with an underscore
fileName += ReportTitle.replace(/ /g, "_");
//Initialize file format you want csv or xls
var uri = "data:text/csv;charset=utf-8," + escape(CSV);
// Now the little tricky part.
// you can use either>> window.open(uri);
// but this will not work in some browsers
// or you will not get the correct file extension
//this trick will generate a temp <a /> tag
var link = document.createElement("a");
link.href = uri;
//set the visibility hidden so it will not effect on your web-layout
link.style = "visibility:hidden";
link.download = fileName + ".csv";
//this part will append the anchor tag and remove it after automatic click
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
};
It takes three inputs –
JSONData
– (JSON) The data to put into sheet. This should be in JSON format.ReportTitle
– (String) The title of the generated CSV file.ShowLabel
– (Boolean) If you want to show the headings in the sheet. In this case, the first record of every column will be treated as heading. Which means, the keys of JSON object will be the headings.
Comments