深入浅出,教你用JS/TS轻松搞定Excel与XML互转

一、 为什么需要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 email
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开发干货。

相关推荐
吃饺子不吃馅18 小时前
AntV X6 核心插件帮你飞速创建画布
前端·css·svg
Ares-Wang19 小时前
Vue2 》》Vue3》》 Render函数 h
javascript
葡萄城技术团队19 小时前
SpreadJS 纯前端表格控件:破解中国式复杂报表技术文档
前端
Humbunklung19 小时前
C# 压缩解压文件的常用方法
前端·c#·压缩解压
通往曙光的路上19 小时前
时隔一天第二阶段他来了 html!!!!!!!!!!!
前端·html
爱吃甜品的糯米团子19 小时前
CSS图片背景属性
前端·css
雮尘19 小时前
一文读懂Android Fragment栈管理
android·前端
Aoda19 小时前
浏览器字体设置引发的Bug:从一次调查到前端字体策略的深度思考
前端·css
朝与暮19 小时前
《javascript进阶-类(class):构造函数的语法糖》
前端·javascript
入秋19 小时前
Three.js 实战之电子围栏可根据模型自动生成
前端·前端框架·three.js