项目多文件JSON数值比对

在开发项目中难免遇到之前前辈开发的代码,其中可能会存在一些JSON文件,比如国际化语言文件、对类型数据文件,但这些文件就有可能存在数据之间缺失、长时间没有更新,多文件中的数据就有数据之间存在差异的文件,要是你来一个个维护,一个个key的对比数据但凡多点这就是巨大的工作量,而且还容易在对比过程中产生遗漏,这样又要重新开始比对。所以就有了通过node.js,写个脚本来比对的必须。

下面两个场景就是对应你对文件对比差异的不同要求。

比对文件,区分差异

比对两个文件中数值的差异,并输入相对差异值

js 复制代码
// merge-objects.mjs
import { writeFileSync } from 'fs';
import { resolve, dirname } from 'path';
import { fileURLToPath, pathToFileURL } from 'url';

// 获取当前文件路径
const __dirname = dirname(fileURLToPath(import.meta.url));

// 解析命令行参数
const [, , file1Path, file2Path, outputPath] = process.argv;

if (!file1Path || !file2Path || !outputPath) {
    console.error('用法: node merge-objects.mjs <文件1> <文件2> <输出文件>');
    process.exit(1);
}

// 异步加载模块
async function loadModule(filePath) {
    try {
        const absolutePath = resolve(__dirname, filePath);
        const moduleUrl = pathToFileURL(absolutePath).href;
        const module = await import(moduleUrl);
        return module.default || module;
    } catch (error) {
        console.error(`无法加载文件 ${filePath}:`, error);
        process.exit(1);
    }
}

// 合并对象
function mergeObjects(obj1, obj2) {
    return {
        ...obj1.config,
        ...obj2.config,
    };
}

// 生成输出内容
function generateOutput(obj) {
    return `// 自动生成的合并对象
export default ${JSON.stringify(
        obj,
        (key, value) => {
            // 处理特殊类型(可选)
            return typeof value === 'function' ? value.toString() : value;
        },
        2,
    )};`;
}

// 主程序
async function main() {
    const obj1 = await loadModule(file1Path);
    const obj2 = await loadModule(file2Path);
    console.log('obj1', obj1);
    console.log('obj2', obj2);
    const merged = mergeObjects(obj1, obj2);

    try {
        const outputContent = generateOutput(merged);
        writeFileSync(resolve(__dirname, outputPath), outputContent);
        console.log(`✅ 合并完成,结果已保存至 ${outputPath}`);
    } catch (error) {
        console.error('写入文件失败:', error);
        process.exit(1);
    }
}

main();

比对文件,合并差异

比对两个文件中数值的差异,已后者为准覆盖前者,合并数值并输入

js 复制代码
import {  writeFileSync } from 'fs';
import { resolve, dirname } from 'path';
import { fileURLToPath, pathToFileURL } from 'url';

// 获取当前文件路径
const __dirname = dirname(fileURLToPath(import.meta.url));
// 读取并解析输入文件
async function readObject(filePath) {
    try {
        const absolutePath = resolve(__dirname, filePath);
        const moduleUrl = pathToFileURL(absolutePath).href;
        const module = await import(moduleUrl);
        return module.default || module;
    } catch (error) {
        console.error(`无法加载文件 ${filePath}:`, error);
        process.exit(1);
    }
}

// 比较两个对象的键,返回差异对象
function getDifference(obj1, obj2) {
    const diff = {};
    const diff2 = {}
    // 获取所有唯一键
    const allKeys = new Set([...Object.keys(obj1), ...Object.keys(obj2)]);    
    allKeys.forEach(key => {
        if (!obj1.hasOwnProperty(key) && obj2.hasOwnProperty(key)) {
            diff2[key] = obj2[key];
        } else if (obj1.hasOwnProperty(key) && !obj2.hasOwnProperty(key)) {
            diff[key] = obj1[key];
        }
    });
    
    return {
        diff,
        diff2
    };
}
// 生成输出内容
function generateOutput(obj) {
    return `// 自动生成的合并对象
export default ${JSON.stringify(
        obj,
        (key, value) => {
            // 处理特殊类型(可选)
            return typeof value === 'function' ? value.toString() : value;
        },
        2,
    )};`;
}
// 主程序
async function main() {
    try {
        const [file1, file2, outputFile] = process.argv.slice(2);
        
        if (!file1 || !file2 || !outputFile) {
            throw new Error('参数不足。用法: node script.js <文件1> <文件2> <输出文件>');
        }

        const obj1 = await readObject(file1);
        const obj2 = await readObject(file2);
        const difference = getDifference(obj1, obj2);
        const outputContent = generateOutput(difference);
        // 写入结果文件
        writeFileSync(resolve(__dirname, outputFile), outputContent);
        console.log(`差异已保存至: ${outputFile}`);
    } catch (error) {
        console.error('错误:', error.message);
        process.exit(1);
    }
}

main();

以上的代码文件通过node运行,注意包含代码的文件以.mjs类型命名,在你创建文件的路径下,这样才能运行文件 运行文件命令

shell 复制代码
node [你的文件名].mjs [第一个文件].js [第二个文件].js
相关推荐
T***u3336 分钟前
前端框架在性能优化中的实践
javascript·vue.js·前端框架
jingling5551 小时前
vue | 在 Vue 3 项目中集成高德地图(AMap)
前端·javascript·vue.js
芳草萋萋鹦鹉洲哦9 小时前
【elemen/js】阻塞UI线程导致的开关卡顿如何优化
开发语言·javascript·ui
1***s63210 小时前
Vue图像处理开发
javascript·vue.js·ecmascript
槁***耿10 小时前
JavaScript在Node.js中的事件发射器
开发语言·javascript·node.js
一叶茶10 小时前
移动端平板打开的三种模式。
前端·javascript
U***498310 小时前
JavaScript在Node.js中的Strapi
开发语言·javascript·node.js
老前端的功夫11 小时前
前端浏览器缓存深度解析:从网络请求到极致性能优化
前端·javascript·网络·缓存·性能优化
颜酱12 小时前
Monorepo 架构以及工具选型、搭建
前端·javascript·node.js
X***489613 小时前
JavaScript在Node.js中的Nx
javascript·node.js·vim