I can propose the following two modules since I have already used them successfully in production (with custom columns also):
- react-data-export
- react-csv
And a third one, after a quick search, which looks promising (I haven't used it though)
- react-export-excel
The library that you are currently using does not support the removal of columns in the excel file according to this issue, which also proposes a fourth option:
- react-csv-creator
EDIT: Ok, I have created two examples.
The first can be found here and uses my 2nd proposal, react-csv
The second is the following, which uses my 3rd proposal, react-export-excel
2nd EDIT: I have updated both examples, the columns now are defined from your object's structure, and two ways of removing the unwanted column are proposed (by key-value firstname
or by index - the 1st one).
Please take into account that the above methods will work successfully if the objects' structure is consistent in your data (each entry should have the same columns).
The camelCase method that I have used in both examples was taken from here.
import React from "react";
import ReactDOM from "react-dom";
import "./styles.css";
import ReactExport from "react-export-excel";
const ExcelFile = ReactExport.ExcelFile;
const ExcelSheet = ReactExport.ExcelFile.ExcelSheet;
const ExcelColumn = ReactExport.ExcelFile.ExcelColumn;
function App () {
const data = [
{ firstname: "jill", lastname: "smith", age: 22 },
{ firstname: "david", lastname: "warner", age: 23 },
{ firstname: "nick", lastname: "james", age: 26 }
];
const camelCase = (str) => {
return str.substring(0, 1).toUpperCase() + str.substring(1);
};
const filterColumns = (data) => {
// Get column names
const columns = Object.keys(data[0]);
// Remove by key (firstname)
const filterColsByKey = columns.filter(c => c !== 'firstname');
// OR use the below line instead of the above if you want to filter by index
// columns.shift()
return filterColsByKey // OR return columns
};
return (
<div className="App">
<ExcelFile filename="test">
<ExcelSheet data={data} name="Test">
{
filterColumns(data).map((col)=> {
return <ExcelColumn label={camelCase(col)} value={col}/>
})
}
</ExcelSheet>
</ExcelFile>
<table id="table-to-xls">
<thead>
<tr>
<th>Firstname</th>
<th>Lastname</th>
<th>Age</th>
</tr>
</thead>
<tbody>
{data.map(item => {
return (
<tr>
<td>{item.firstname}</td>
<td>{item.lastname}</td>
<td>{item.age}</td>
</tr>
);
})}
</tbody>
</table>
</div>
);
}
const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…