amm*_*mmy 5 reactjs react-native
我需要从 Excel 中获取数据并将其以 Json 格式存储为键值对。我怎样才能在反应中做到这一点?
\n\n\n\n预期o/p-
\n\n{\n"Segment": "Air",\n"TripName":"Test\xc2\xa0UI\xc2\xa0Flow",\n"startDate":"6/19/2020",\n"endDate":" 2020 年 6 月 25 日",\n"总票价":"3948"\n}
\n小智 5
这里有一个将(xlsx)Excel文件转换为json的方法。我已经使它从本地文件系统(即桌面等)获取文件。但是您可以轻松地将其转换为从服务器获取文件。
import React, { useState } from "react";
import "./App.css";
import * as XLSX from "xlsx";
class ExcelToJson extends React.Component {
constructor(props) {
super(props);
this.handleClick = this.handleClick.bind(this);
this.state = {
file: "",
};
}
handleClick(e) {
this.refs.fileUploader.click();
}
filePathset(e) {
e.stopPropagation();
e.preventDefault();
var file = e.target.files[0];
console.log(file);
this.setState({ file });
console.log(this.state.file);
}
readFile() {
var f = this.state.file;
var name = f.name;
const reader = new FileReader();
reader.onload = (evt) => {
// evt = on_file_select event
/* Parse data */
const bstr = evt.target.result;
const wb = XLSX.read(bstr, { type: "binary" });
/* Get first worksheet */
const wsname = wb.SheetNames[0];
const ws = wb.Sheets[wsname];
/* Convert array of arrays */
const data = XLSX.utils.sheet_to_csv(ws, { header: 1 });
/* Update state */
console.log("Data>>>" + data);// shows that excel data is read
console.log(this.convertToJson(data)); // shows data in json format
};
reader.readAsBinaryString(f);
}
convertToJson(csv) {
var lines = csv.split("\n");
var result = [];
var headers = lines[0].split(",");
for (var i = 1; i < lines.length; i++) {
var obj = {};
var currentline = lines[i].split(",");
for (var j = 0; j < headers.length; j++) {
obj[headers[j]] = currentline[j];
}
result.push(obj);
}
//return result; //JavaScript object
return JSON.stringify(result); //JSON
}
render() {
return (
<div>
<input
type="file"
id="file"
ref="fileUploader"
onChange={this.filePathset.bind(this)}
/>
<button
onClick={() => {
this.readFile();
}}
>
Read File
</button>
</div>
);
}
}
export default ExcelToJson;
Run Code Online (Sandbox Code Playgroud)
控制台登录 readFile 函数获取 json 格式的数据。
| 归档时间: |
|
| 查看次数: |
17869 次 |
| 最近记录: |