一、 为什么需要Excel与XML互转?
项目需求:
- 数据导入导出: 比如我工作时候遇到的
fairygui
多语言,导出的是xml文件,策划需要Excel文件。 - 配置管理 、数据迁移 等,本质就是需求双方出现了对数据格式要求的不一致。
在这些场景下,程序化的Excel与XML转换能力就显得尤为重要。它能帮助我们告别繁琐的手动操作,实现数据的自动化、批量化处理。
二、 核心工具库安装
2.1 安装依赖
bash
npm install xlsx xml2js ts-node typescript @types/node xml-js
npm install @types/xml2js @types/xlsx @types/xml-js -D
三、 Excel 转换为 XML
这个过程的核心思想是:读取Excel数据 -> 将数据构造成JavaScript对象 -> 将JavaScript对象转换为XML格式。
3.1 读取Excel数据并转换成Json对象
假设我们有一个名为 users.xlsx
的Excel文件,内容如下:
id | name | |
---|---|---|
1 | Alice | alice@163.com |
2 | Bob | bob@163.com |
3 | Charlie | charlie@163.com |
我们可以使用 xlsx
来读取它:
typescript
import * as XLSX from 'xlsx';
// 读取Excel文件
const workbook = XLSX.readFile('users.xlsx');
// 获取第一个工作表
const sheetName = workbook.SheetNames[0];
const worksheet = workbook.Sheets[sheetName];
// 将工作表转换为JSON对象数组
const jsonData = XLSX.utils.sheet_to_json<{ id: number; name: string; email: string }>(worksheet);
console.log(jsonData);
/*
输出:
[
{ id: 1, name: 'Alice', email: 'Alice@163.com' },
{ id: 2, name: 'Bob', email: 'Bob@163.com' },
{ id: 3, name: 'Charlie', email: 'Charlie@163.com' }
]
*/
3.2 将JSON数据转换为XML
现在我们有了JavaScript对象数组,接下来使用 xml-js
将其转换为XML格式。
typescript
import * as convert from 'xml-js';
// 假设 jsonData 来自上一步
const dataForXml = {
_declaration: { _attributes: { version: '1.0', encoding: 'utf-8' } },
users: {
user: jsonData.map((u) => ({
_attributes: { id: u.id },
name: { _text: u.name },
email: { _text: u.email },
})),
},
};
const xmlData = convert.js2xml(dataForXml, { compact: true, spaces: 4 });
console.log(xmlData);
输出的XML结果 (output.xml
):
xml
<?xml version="1.0" encoding="utf-8"?>
<users>
<user id="1">
<name>Alice</name>
<email>Alice@163.com</email>
</user>
<user id="2">
<name>Bob</name>
<email>Bob@163.com</email>
</user>
<user id="3">
<name>Charlie</name>
<email>Charlie@163.com</email>
</user>
</users>
四、XML 转换为 Excel
反向操作的思路同样清晰:读取XML数据 -> 将XML解析为JavaScript对象 -> 将JavaScript对象生成为Excel文件。
4.1 读取并解析XML数据
假设我们有上一节生成的 output.xml
文件。
typescript
import * as fs from 'fs';
import * as convert from 'xml-js';
// 读取XML文件内容
const xmlFile = fs.readFileSync('output.xml', 'utf8');
// 将XML转换为JavaScript对象
const jsonDataFromXml = convert.xml2js(xmlFile, { compact: true }) as any;
// 提取我们需要的用户数据数组
const users = jsonDataFromXml.users.user.map((u: any) => ({
id: u._attributes.id,
name: u.name._text,
email: u.email._text,
}));
console.log(users);
/*
[
{ id: '1', name: 'Alice', email: 'alice@163.com' },
{ id: '2', name: 'Bob', email: 'bob@163.com' },
{ id: '3', name: 'Charlie', email: 'charlie@163.com' }
]
*/
4.2:将JSON数据生成Excel文件
得到JavaScript对象数组后,我们再次请出 xlsx
来完成最后一步。
typescript
import * as XLSX from 'xlsx';
// 1. 创建一个新的工作簿
const newWorkbook = XLSX.utils.book_new();
// 2. 将JSON数据转换为工作表
const newWorksheet = XLSX.utils.json_to_sheet(users);
// 3. 将工作表附加到工作簿,并命名为 "Users"
XLSX.utils.book_append_sheet(newWorkbook, newWorksheet, 'Users');
// 4. 生成Excel文件并写入磁盘
XLSX.writeFile(newWorkbook, 'users_from_xml.xlsx');
总结
如果你喜欢本教程,记得点赞+收藏!关注我获取更多JavaScript开发干货。