多个JSON文件中目标Key值检索

摘要:工作中需要将Excel中的文件名,与JSON文件逐个匹配,并查找其中目标key的值是否满足条件,尝试写了个JS脚本实现下...

1. 安装xlsx库

首先,需要安装xlsx库,允许用户在Node.js和浏览器环境中读写Excel文件。安装步骤简单

bash 复制代码
npm install xlsx

2. 创建脚本逐步实现功能

2.1 从Excel文件读取文件名并与JSON文件匹配

由于Excel中文件名称不完整,需要处理后,才能与JSON文件名称正确匹配

javascript 复制代码
// 从Excel文件读取文件名模式
async function getFileNamesFromExcel(excelFilePath) {
  // 读取Excel文件
  const workbook = XLSX.readFile(excelFilePath);
  // 获取第一个工作表
  const sheetName = workbook.SheetNames[0];
  const sheet = workbook.Sheets[sheetName];
  // 将工作表转换为JSON对象数组
  const data = XLSX.utils.sheet_to_json(sheet, { header: 1 });
  
  // 提取文件名列的值作为文件名模式数组
  const patterns = data.map(row => {
    return '前缀'+row[10]+ '.json';
  });
  return patterns;
}
2.2 读取JSON文件检查是否满足条件

按照Excel中匹配后的文件名,这个查找JSON文件,并判断是否满足条件

javascript 复制代码
// 读取并检查JSON文件
async function checkSpecifiedJsonFiles(fileNamesFromExcel, configsDir) {
  for (const fileNameFromExcel of fileNamesFromExcel) {
    const jsonFileName = fileNameFromExcel; //
    const filePath = path.join(configsDir, jsonFileName);

    try {
      // 读取文件
      const content = await fs.readFile(filePath, 'utf8');
      const config = JSON.parse(content);

      // 这里定义需求:检查 "targetKey1" 和 "targetKey2" 字段
      const targetKey1 = config.targetKey1;
      const targetKey2 = config.targetKey2;

      if (targetKey1 === true || targetKey1 === true) {
        console.log(`文件 ${jsonFileName} 不满足需求。`);
      } else {
        console.log(`文件 ${jsonFileName} 满足需求。`);
      }
    } catch (error) {
      if (error.code === 'ENOENT') {
        // 文件不存在
        console.log(`文件 ${jsonFileName} 不存在。`);
      } else {
        // 其他错误
        console.error(`处理文件 ${jsonFileName} 时发生错误:`, error);
      }
    }
  }
}

// 主函数
async function main() {
  try {
    const fileNames = await getFileNamesFromExcel(excelFilePath);
    await checkSpecifiedJsonFiles(fileNames, configsDir);
  } catch (error) {
    console.error('发生错误:', error);
  }
}

完整脚本:

javascript 复制代码
const fs = require('fs').promises;
const path = require('path');
const XLSX = require('xlsx');

// 假设Excel文件名为fileNames.xlsx, 并且JSONChecker和JSONDirector位于同一目录下
const excelFilePath = '/Users/JSONChecker/fileNames.xlsx';
const configsDir = '/Users/JSONDirectory';  // JSON配置文件的目录(绝对路径)

// 从Excel文件读取文件名模式
async function getFileNamesFromExcel(excelFilePath) {
  // 读取Excel文件
  const workbook = XLSX.readFile(excelFilePath);
  // 获取第一个工作表
  const sheetName = workbook.SheetNames[0];
  const sheet = workbook.Sheets[sheetName];
  // 将工作表转换为JSON对象数组
  const data = XLSX.utils.sheet_to_json(sheet, { header: 1 });
  
  // 提取row[10]列的值作为文件名模式数组
  const patterns = data.map(row => {
    return '前缀'+row[10]+ '.json';
  });
  return patterns;
}

// 读取并检查JSON文件
async function checkSpecifiedJsonFiles(fileNamesFromExcel, configsDir) {
  for (const fileNameFromExcel of fileNamesFromExcel) {
    const jsonFileName = fileNameFromExcel; //
    const filePath = path.join(configsDir, jsonFileName);

    try {
      // 读取文件
      const content = await fs.readFile(filePath, 'utf8');
      const config = JSON.parse(content);

      // 这里定义需求:检查 "targetKey1" 和 "targetKey2" 字段
      const targetKey1 = config.targetKey1;
      const targetKey2 = config.targetKey2;

      if (targetKey1 === true || targetKey1 === true) {
        console.log(`文件 ${jsonFileName} 不满足需求。`);
      } else {
        console.log(`文件 ${jsonFileName} 满足需求。`);
      }
    } catch (error) {
      if (error.code === 'ENOENT') {
        // 文件不存在
        console.log(`文件 ${jsonFileName} 不存在。`);
      } else {
        // 其他错误
        console.error(`处理文件 ${jsonFileName} 时发生错误:`, error);
      }
    }
  }
}

// 主函数
async function main() {
  try {
    const fileNames = await getFileNamesFromExcel(excelFilePath);
    await checkSpecifiedJsonFiles(fileNames, configsDir);
  } catch (error) {
    console.error('发生错误:', error);
  }
}

// 执行主函数
main();

3. 总结

将Excel文件保存为fileNames.xlsx,并确保它位于脚本所在目录下。Excel文件应该有一个列row[10],其中包含需要检查的JSON文件的名称。运行上述脚本即可按照Excel中文件顺序输出结果

bash 复制代码
node parentDirectory/JSONChecker/JSONChecker.js
相关推荐
Lupino24 分钟前
被 React “玩弄”的 24 小时:为了修一个不存在的 Bug,我给大模型送了顿火锅钱
前端·react.js
米丘31 分钟前
了解 Javascript 模块化,更好地掌握 Vite 、Webpack、Rollup 等打包工具
前端
Heo32 分钟前
深入 React19 Diff 算法
前端·javascript·面试
滕青山34 分钟前
个人所得税计算器 在线工具核心JS实现
前端·javascript·vue.js
小怪点点34 分钟前
手写promise
前端·promise
国思RDIF框架43 分钟前
RDIFramework.NET Web 敏捷开发框架 V6.3 发布 (.NET8+、Framework 双引擎)
前端
颜酱44 分钟前
从0到1实现LFU缓存:思路拆解+代码落地
javascript·后端·算法
Mintopia44 分钟前
如何在有限的时间里,活出几倍的人生
前端
炫饭第一名1 小时前
速通Canvas指北🦮——变形、渐变与阴影篇
前端·javascript·程序员
Neptune11 小时前
让我带你迅速吃透React组件通信:从入门到精通(上篇)
前端·javascript