Node.js中JSON格式和Excel格式的双向转换

 4603

本篇文章带大家了解一下前端如何使用Node.js实现JSON格式转Excel 文件,Excel格式转JSON文件,介绍一下它们进行转换的流程,希望对大家有所帮助。


Node.js中JSON格式和Excel格式的双向转换


通常情况下我们 老板 / 客户 想要的数据是以直观的 Excel 格式展示出来,但我们前端或者后端的数据都是 JSON 格式的,那么就需要进行 JSON -> Excel 的文件格式转换;如果我们做了一个网页,里面有个<table>组件,要实现一个功能:导出为 Excel / 导入 Excel,那么就需要进行 JSON <-> Excel 的文件格式

把 JSON 转换成 Excel 文件

流程

利用 fs 模块读入数据并使用JSON.parse()方法转换格式

遍历数据,处理得到 Object

利用 json2xls 模块转换 Object 得到变量,利用 fs 模块写出 Excel

例子

参考 nodeJS把json数据转成excel(xlsx文件)输出 的例子,借助其需求:网站爬虫爬取到的数据转换为 Excel 文件:


data.json


60f7686690212.png


result.xlsx


60f7696b59866.png


代码

需要引入的 npm 包有 fs、json2xls

  1. const fs = require('fs')
  2. const json2xls = require('json2xls');
  3.  
  4. fs.readFile('data.json','utf8',(err,data)=>{
  5.   if (err) throw err;
  6.   const json = JSON.parse(data);
  7.   const jsonArray = [];
  8.   json.forEach(function(item){
  9.     let temp = {
  10.       '类型' : item.type,
  11.       '问题' : item.question,
  12.       '选项' : item.answers,
  13.       '答案' : item.trueAnswer
  14.     }
  15.     jsonArray.push(temp);
  16.   });
  17.    
  18.   let xls = json2xls(jsonArray);
  19.    
  20.   fs.writeFileSync('result.xlsx', xls, 'binary');
  21. })


把 Excel 转换成 JSON 文件

流程

读取本地 Excel 文件到变量暂存;

处理变量数据;(根据各自需求处理)

处理后的数据写入本地 JSON 文件

例子

参考 Node.js excel转json 文章,借助其需求:把 data.xlsx 文件转换成 result.json


data.xlsx


60f76a8aa9405.png


result.json


60f76aa20bb1b.png


代码

需要引入的 npm 包有 fs、node-xlsx,步骤按照上面的三部曲

  1. var xlsx = require("node-xlsx");
  2. var fs = require('fs');
  3. var list = xlsx.parse("raw-data.xlsx"); // 需要转换的excel文件
  4.  
  5. var data = list[0].data;  // 1.读取json数据到变量暂存
  6. var len = data.length;
  7. var outData_cn = {}; // 中文
  8. var outData_us = {}; // 英文
  9. for(let i = 0; i < len; i ++){  // 2. 数据处理
  10.     let item = data[i];
  11.     outData_cn[item[0]] = item[1];
  12.     outData_us[item[0]] = item[2];
  13. }
  14. var outData = {
  15.     cn: outData_cn,
  16.     us: outData_us
  17. }
  18.  
  19. fs.writeFile("result.json",JSON.stringify(outData),'utf-8',complete);  //  3. 数据写入本地json文件
  20. //           输出的json文件        数据          文件编码格式 完成事件
  21. function complete(err) {
  22.    if(!err) console.log("文件生成成功");
  23. }



本文网址:https://www.zztuku.com/index.php/detail-9028.html
站长图库 - Node.js中JSON格式和Excel格式的双向转换
申明:如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐

    jQuery汽车车速表效果