Nodejs excel(.xlsx) 文件读写
data.xlsx
名字 年龄 张三 18 李四 19 王五 20
获取数据
import xlsx from "xlsx";
const workBook = xlsx.readFile("./data.xlsx");??
获取第一个 execle 工作簿表格
let name = workBook.SheetNames[0] let sheet = workBook.Sheets[name]
1. 输出 json 格式
console.log(xlsx.utils.sheet_to_json(sheet));
[
?? ?{
?? ??? ?名字:"张三",
?? ??? ?年龄:"18"?? ?
?? ?},
?? ?{
?? ??? ?名字:"李四",
?? ??? ?年龄:"19"
?? ?},
?? ?{
?? ??? ?名字:"王五",
?? ??? ?年龄:"20"
?? ?}
]
2. 输出 csv 格式
console.log(xlsx.utils.sheet_to_csv(sheet));
名字,年龄,,,,,,,,,,,,,,,,,
张三,18,,,,,,,,,,,,,,,,,
李四,19,,,,,,,,,,,,,,,,,
王五,20,,,,,,,,,,,,,,,,,
3. 输出 html 格式
console.log(xlsx.utils.sheet_to_html(sheet));
<html><head><meta charset="utf-8"/><title>SheetJS Table Export</title></head><body><table><tr><td data-t="s" data-v="名字" id="sjs-A1">名字</td><td data-t="s" data-v="年龄" id="sjs-B1">年龄</td></tr><tr><td data-t="s" data-v="张三" id="sjs-A2">张三</td><td data-t="n" data-v="18" id="sjs-B2">18</td></tr><tr><td data-t="s" data-v="李四" id="sjs-A3">李四</td><td data-t="n" data-v="19" id="sjs-B3">19</td></tr><tr><td data-t="s" data-v="王五" id="sjs-A4">王五</td><td data-t="n" data-v="20" id="sjs-B4">20</td></tr></table></body></html>
4.输出 formulae 格式
console.log(xlsx.utils.sheet_to_formulae(sheet));
[ "A1='名字", "B1='年龄", "A2='张三", 'B2=18', "A3='李四", 'B3=19', "A4='王五", 'B4=20' ]
输出成文件
xlsx.writeFile(workBook, "./output.xlsx");
全部代码
import xlsx from "xlsx";
const workBook = xlsx.readFile("./data.xlsx");
let name = workBook.SheetNames[0];
let sheet = workBook.Sheets[name];
console.log(xlsx.utils.sheet_to_json(sheet));
console.log(xlsx.utils.sheet_to_csv(sheet));
console.log(xlsx.utils.sheet_to_html(sheet));
console.log(xlsx.utils.sheet_to_formulae(sheet));
xlsx.writeFile(workBook, "./output.xlsx");
方法封装
import xlsx from "xlsx";
/**
* 解析 excel 文件成 json 对象
* @param {string} filePath
*/
export function parseExcel(filePath) {
// 读取文件并解析工作簿
const workBook = xlsx.readFile(filePath);
// 获取第一个表格
let name = workBook.SheetNames[0];
// 解析表格
return xlsx.utils.sheet_to_json(workBook.Sheets[name]);
}
/**
* 将对象数据解析成 excel
* @param {string} filePath 路径
* @param {Array} list 数据
* @param {string} sheetName 表格名字, 默认 Sheet1
*/
export function writeExcel(filePath, list, sheetName = "Sheet1") {
// 新建工作簿
const workBook = xlsx.utils.book_new();
// 添加表格
xlsx.utils.book_append_sheet(workBook, xlsx.utils.json_to_sheet(list), sheetName);
// 输出文件
xlsx.writeFile(workBook, filePath);
}
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
查看更多关于Nodejs excel(.xlsx) 文件的读写方式的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://haodehen.cn/did120809