Node.js中JSON格式和Excel格式的雙向轉(zhuǎn)換方法

這篇文章主要講解了“Node.js中JSON格式和Excel格式的雙向轉(zhuǎn)換方法”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“Node.js中JSON格式和Excel格式的雙向轉(zhuǎn)換方法”吧!

創(chuàng)新互聯(lián)建站是一家專業(yè)提供靜海企業(yè)網(wǎng)站建設(shè),專注與成都做網(wǎng)站、成都網(wǎng)站制作、HTML5建站、小程序制作等業(yè)務(wù)。10年已為靜海眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進(jìn)行中。

把 JSON 轉(zhuǎn)換成 Excel 文件

流程

  • 利用 fs 模塊讀入數(shù)據(jù)并使用JSON.parse()方法轉(zhuǎn)換格式

  • 遍歷數(shù)據(jù),處理得到 Object

  • 利用 json2xls 模塊轉(zhuǎn)換 Object 得到變量,利用 fs 模塊寫出 Excel

例子

參考 nodeJS把json數(shù)據(jù)轉(zhuǎn)成excel(xlsx文件)輸出 的例子,借助其需求:網(wǎng)站爬蟲爬取到的數(shù)據(jù)轉(zhuǎn)換為 Excel 文件:

data.json

Node.js中JSON格式和Excel格式的雙向轉(zhuǎn)換方法

result.xlsx

Node.js中JSON格式和Excel格式的雙向轉(zhuǎn)換方法

代碼

需要引入的 npm 包有 fs、json2xls

const fs = require('fs')
const json2xls = require('json2xls');

fs.readFile('data.json','utf8',(err,data)=>{
  if (err) throw err;
  const json = JSON.parse(data);
  const jsonArray = [];
  json.forEach(function(item){
    let temp = {
      '類型' : item.type,
      '問題' : item.question,
      '選項(xiàng)' : item.answers,
      '答案' : item.trueAnswer
    }
    jsonArray.push(temp);
  });
  
  let xls = json2xls(jsonArray);
  
  fs.writeFileSync('result.xlsx', xls, 'binary');
})

把 Excel 轉(zhuǎn)換成 JSON 文件

流程

  • 讀取本地 Excel 文件到變量暫存;

  • 處理變量數(shù)據(jù);(根據(jù)各自需求處理)

  • 處理后的數(shù)據(jù)寫入本地 JSON 文件

例子

參考 Node.js excel轉(zhuǎn)json 文章,借助其需求:把 data.xlsx 文件轉(zhuǎn)換成 result.json

data.xlsx

Node.js中JSON格式和Excel格式的雙向轉(zhuǎn)換方法

result.json

Node.js中JSON格式和Excel格式的雙向轉(zhuǎn)換方法

代碼

需要引入的 npm 包有 fsnode-xlsx,步驟按照上面的三部曲

var xlsx = require("node-xlsx");
var fs = require('fs');
var list = xlsx.parse("raw-data.xlsx"); // 需要轉(zhuǎn)換的excel文件

var data = list[0].data;  // 1.讀取json數(shù)據(jù)到變量暫存
var len = data.length;
var outData_cn = {}; // 中文
var outData_us = {}; // 英文
for(let i = 0; i < len; i ++){  // 2. 數(shù)據(jù)處理
    let item = data[i];
    outData_cn[item[0]] = item[1];
    outData_us[item[0]] = item[2];
}
var outData = {
    cn: outData_cn,
    us: outData_us
}

fs.writeFile("result.json",JSON.stringify(outData),'utf-8',complete);  //  3. 數(shù)據(jù)寫入本地json文件
//           輸出的json文件        數(shù)據(jù)          文件編碼格式 完成事件
function complete(err) {
   if(!err) console.log("文件生成成功");
}

感謝各位的閱讀,以上就是“Node.js中JSON格式和Excel格式的雙向轉(zhuǎn)換方法”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)Node.js中JSON格式和Excel格式的雙向轉(zhuǎn)換方法這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

當(dāng)前名稱:Node.js中JSON格式和Excel格式的雙向轉(zhuǎn)換方法
網(wǎng)站路徑:http://muchs.cn/article44/johoee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、做網(wǎng)站營(yíng)銷型網(wǎng)站建設(shè)、用戶體驗(yàn)、品牌網(wǎng)站建設(shè)、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)