Maison >interface Web >js tutoriel >Parlons de la façon d'utiliser Node pour convertir Excel en JSON
Comment utiliser Node pour convertir Excel en JSON ? L'article suivant vous présentera comment convertir Excel en JSON dans Node J'espère qu'il vous sera utile !
Actuellement, je souhaite utiliser Cocos Creator
pour créer un jeu de mots, similaire à My Life Restart Simulator
. Cocos Creator
做一个文字游戏,类似于我的人生重开模拟器
。
那么其中最重要的一点就是关于数据的存储了。在我的人生重开模拟器
中大部分事件和天赋的数据是存储在excel
表格当中的,当然如果要使用Cocos Creator
,因为我不准备布置服务器,所以需要将数据提前转换成JSON
文件,那么可以创建一个项目,使用node读取excel
文件,并通过格式转换,将数据转换成JSON
。【相关教程推荐:nodejs视频教程】
这里网上有一些node调用excel
的库,我使用了node-xlsx
,此库底层基于强大的 SheetJS 构建,对 xlsx 文档的格式兼容性足够好。
npm地址:node-xlsx - npm (npmjs.com)
在此之前我已经新建了一个天赋表格talentTable.xlsx
,里面已经添加了许多天赋,并且有不同的属性加成
pnpm init
创建一个项目,然后使用pnpm add node-xlsx
将库导入项目当中。
创建一个主文件excelMain.js
,此文件中需要引入需要的库
import { fileURLToPath } from 'node:url' import path from 'path'; import fs from 'fs'; import xlsx from 'node-xlsx';
可以提前先将需要的存储的json文件talent.json
创建好,通过path
将xlsx和json的文件夹相对路径找到
// 获取 __dirname 的 ESM 写法 const __dirname = path.dirname(fileURLToPath(import.meta.url)) // xlsx文件路径 const xlsxPath = path.resolve(__dirname, '../../assets/JsonData');
因为我有很几个表格,所以可以创建一个表格的路径对象
// 事件, 玩家, 门派, 天赋, 武学 let dataNames = ['event', 'player', 'sect', 'talent', 'skill'] let dataPaths = {}; for(let iname of dataNames) { dataPaths[iname] = { xlsx: path.resolve(xlsxPath, `./${iname}Table.xlsx`), json: path.resolve(xlsxPath, `./${iname}.json`) } }
然后创建一个读取文件方法,这里需要用到fs
中的readFileSync
// 读取数据表方法 const readFileData = (tableName)=>{ let fname = dataPaths[tableName].xlsx const xlsxData = xlsx.parse(fs.readFileSync(fname)); ...... }
这里读取到的xlsxData
是一个数组对象,数组中的元素代表的其实是一张张sheet表格,xlsx表格中并不是只有一个表格,所以才会是数组对象,不过我需要的只是第一张表格。
所以获取xlsxData[0].data
的数据即可,data的数据是按照行排列的数组对象
然后到转换成JSON格式数据是,需要变成属性:属性值
的格式,所以可创建一个方法,将第一行属性和从第三行开始的数据结合,创建一个对象数组。
const oneAndTwo = (arr)=>{ if (arr.length <= 2) return []; let newarr = [] for(let i = 2; i < arr.length; i++) { let newobj = {}; for(let j = 0; j < arr[0].length; j++) { let jname = arr[0][j]; newobj[jname] = (arr[i][j] != undefined)? arr[i][j] : null; } newarr.push(newobj) } return newarr; }
这样返回的对象就如下了
接下来就可以将数据开始写入json文件当中,使用fs.writeFile
方法,格式使用utf-8
即可
// 写入JSON文件方法 const writeJson = (arr, jsonName)=>{ let path = dataPaths[jsonName].json; let d = { data: arr } fs.writeFile(path, JSON.stringify(d), 'utf-8', (err)=>{ console.log(`${jsonName}写入成功`); }); }
这样需要的游戏固定事件和天赋数据json就可以出现了。
对于JSON数据存储为excel
对象也比较容易,需要用到xlsx.build
方法,这里就不做过多的介绍了,可以去参考npm
My Life Restart Simulator
, la plupart des données d'événements et de talents sont stockées dans des tables excel
. Bien sûr, si vous souhaitez utiliser Cocos Creator
, car. Je n'ai pas l'intention de déployer un serveur, je dois donc convertir les données en un fichier JSON
à l'avance. Ensuite, je peux créer un projet, utiliser node pour lire le excel fichier, et convertissez-le via le format . convertissez les données en <code>JSON
. [Recommandations de didacticiel associées : Tutoriel vidéo Nodejs]
Il existe certaines bibliothèques sur Internet qui utilisent node pour appelerexcel
. J'ai utilisé node-xlsx
. de cette bibliothèque est basée sur le puissant SheetJS et construit avec une compatibilité de format suffisamment bonne pour les documents xlsx. 🎜🎜Adresse npm : node-xlsx - npm (npmjs.com)🎜🎜talentTable.xlsx
, qui a ajouté de nombreux talents et a différents bonus d'attributs🎜🎜🎜🎜pnpm init
Créez un projet puis utilisez pnpm add node-xlsx
Importez la bibliothèque dans le projet. 🎜🎜Créez un fichier principal excelMain.js
Les bibliothèques requises doivent être introduites dans ce fichier🎜rrreee🎜Vous pouvez créer le fichier json stocké requis talent.json
à l'avance. , recherchez les chemins relatifs des dossiers xlsx et json via path
🎜rrreee🎜Parce que j'ai de nombreuses tables, je peux créer un objet chemin de table🎜rrreee🎜🎜🎜Créez ensuite une méthode de lecture de fichier, qui doit être utilisée ici. Allez à readFileSync
dans fs
🎜rrreee🎜Le xlsxData
lu ici est un objet tableau, et les éléments du tableau représentent en fait un Il n'y a pas seulement une table dans la table xlsx, c'est donc un objet tableau, mais tout ce dont j'ai besoin c'est de la première table. 🎜🎜🎜🎜🎜🎜 alors récupèrexlsxData[0].data
suffit. Les données de data sont un objet tableau disposé en lignes🎜🎜🎜🎜Ensuite, pour convertir les données au format JSON, elles doivent être modifiées au format Attribut : Valeur d'attribut , afin que vous puissiez créer une méthode qui combine les propriétés de la première ligne avec les données à partir de la troisième ligne pour créer un tableau d'objets. 🎜rrreee🎜L'objet renvoyé est le suivant🎜🎜<img src="https://img.php.cn/upload/article/000/000/024/a83811fb7c9b4d11b99a35c6a2444f77-5.png" alt="Parlons de la façon dutiliser Node pour convertir Excel en JSON" chargement="lazy">🎜🎜Ensuite, vous pouvez commencer à écrire les données dans le fichier json, utiliser la méthode <code>fs.writeFile
, et le format est utf-8
🎜 rrreee 🎜🎜🎜🎜🎜 Un jeu si nécessaire Corrigé les données d'événement et de talent json apparaîtront. 🎜🎜Il est également plus facile de stocker des données JSON sous forme d'objets excel
. Vous devez utiliser la méthode xlsx.build
. Je n'entrerai pas dans les détails ici. peut se référer à la npm
Méthode d'utilisation à l'adresse. 🎜🎜Pour plus de connaissances sur les nœuds, veuillez visiter : 🎜tutoriel Nodejs🎜 ! 🎜Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!