js对象转换为excel,excel转换为js对象

文章目录


前言

使用module.exports导出,require导入

修改后缀为mjs,可使用importd导入 ,export default \export导出(自用过一次,后面忘记怎么改的了)

js转excel

需要安装nodejs

node excel_.js运行

js对象转换excel逻辑

js 复制代码
const obj = require("./en.js")
var excel=[]
const obj_jcet=(data)=>{
  data.forEach(item=>{
      if(typeof item[1] == 'object'){
         //
         const obj1_1=Object.entries(item[1])
         excel.push({en:item[0],key:'',value:''})
         obj_jcet(obj1_1)
      }else if(typeof item[1] == 'string'){
        excel.push({key:item[0],value:item[1]})
      }
  })
}
obj_jcet(Object.entries(obj))
module.exports=excel

js 复制代码
const {utils, writeFile }=require("xlsx")
const excel =require("./index.js")
// 示例对象数据
const data = excel

// 创建工作簿
const workbook = utils.book_new();

// 创建工作表
const worksheet = utils.json_to_sheet(data);
worksheet["!rows"] = [{wch:500},{wch:500},{wch:500}]
// 将工作表添加到工作簿
utils.book_append_sheet(workbook, worksheet, 'Sheet1');

// 将工作簿写入文件
writeFile(workbook, 'en.xlsx');

console.log('Excel文件已创建成功!');

excel转js对象

打印SheetNames,然后按需去判断即可

js 复制代码
//xlsx转换js文件  已完成

const fs = require("fs");

const xlsx = require("xlsx");  // 想要直接操作本地文件只能采用nodejs的方式,client端无法处理

const {Sheets,SheetNames} = xlsx.readFile("271023.xlsx",{}) // 获取整个xlsx文档

let output = []

SheetNames.forEach(item => {
    const arr = xlsx.utils.sheet_to_json(Sheets[item],{ header: 2 })
    output.push(arr)
}) 
var obj={
  "a":[]
}

output[0].forEach(item=>{
  if(item.hasOwnProperty('PARAMETERS') ==true){
    obj.a.push(`${item.PARAMETERS} = ${item.Spanish}`)
  }
  
})
console.log(obj);
fs.writeFileSync('./language_es.json',JSON.stringify(obj));

总结

相关推荐
前端小趴菜05几秒前
React - 组件通信
前端·react.js·前端框架
Amy_cx20 分钟前
在表单输入框按回车页面刷新的问题
前端·elementui
沉到海底去吧Go33 分钟前
【行驶证识别成表格】批量OCR行驶证识别与Excel自动化处理系统,行驶证扫描件和照片图片识别后保存为Excel表格,基于QT和华为ocr识别的实现教程
自动化·ocr·excel·行驶证识别·行驶证识别表格·批量行驶证读取表格
dancing99934 分钟前
cocos3.X的oops框架oops-plugin-excel-to-json改进兼容多表单导出功能
前端·javascript·typescript·游戏程序
后海 0_o1 小时前
2025前端微服务 - 无界 的实战应用
前端·微服务·架构
Scabbards_1 小时前
CPT304-2425-S2-Software Engineering II
前端
小满zs1 小时前
Zustand 第二章(状态处理)
前端·react.js
程序猿小D1 小时前
第16节 Node.js 文件系统
linux·服务器·前端·node.js·编辑器·vim
萌萌哒草头将军1 小时前
🚀🚀🚀Prisma 发布无 Rust 引擎预览版,安装和使用更轻量;支持任何 ORM 连接引擎;支持自动备份...
前端·javascript·vue.js
狼性书生1 小时前
uniapp实现的简约美观的星级评分组件
前端·uni-app·vue·组件