文章目录
data.xlsx
名字 | 年龄 |
---|---|
张三 | 18 |
李四 | 19 |
王五 | 20 |
获取数据
xlsx 可以运行在网页端以及nodejs客户端,但在网页端运行中需要注意引入(打包)问题,这里就不详细讨论。
import xlsx from "xlsx";
// 通过文件读取
const workBook = xlsx.readFile("./data.xlsx");
// 通过数据读取
// 这里注意,传递的第一个参数必须要与 type 中的数据格式对应,传的是 array 数据, type 就必须是 "array"
const array = 'Unit8Array 或者 ArrayBuffer'
const workBook = xlsx.read(array,{type:"array"})
const base64 = 'base64字符串'
const workBook = xlsx.read(base64,{type:"base64"})
获取第一个 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");
网页端导出文件
// 这里不需要写路径,写文件名,会弹出弹窗让用户选择保存路径
xlsx.writeFile(workBook,'表格.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 对象
*/
export function parseExcel(data,type) {
const workBook = xlsx.read(data, { type });
const excel = workBook.SheetNames.map((name) => ({
SheetName: name,
data: xlsx.utils.sheet_to_json(workBook.Sheets[name]) as any[]
}));
}
/**
* 将对象数据解析成 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);
}