zoukankan      html  css  js  c++  java
  • Node读取和写入json,格式化输出json

    今天是在深信服实习的第5天,接到任务要做产品的外语版,Web端的实习生目前只有我一个,前端和PHP的都要我来做。。。

    现在需要一个写一个脚本,处理两个json文件,把Bjson文件在A中没有的中文词条都要找出来写入另外一个json,实际需求要复杂得多,先写个初步demo:

    var fs = require('fs'),
        path = require('path');
    let ans = {};
    
    //求一方的差集(不是严格意义上的差集,只是一边的)
    function diff(a, b) {
        var keysA = Object.keys(a);
        // console.log(keysA);
        var keysB = Object.keys(b);
        // console.log(keysB)
        var ret = {}
        keysB.forEach(key => {
            if (keysA.indexOf(key) === -1) {
                ret[key] = b[key];
            }
        });
        return ret;
    }
    
    
    fs.readFile(path.join(__dirname, 'json/json1.json'), 'utf8',function (err,data1) {
        if (err) throw err;
        // console.log(data1);
        data1 = JSON.parse(data1)
        // console.log(typeof data1);
    
        fs.readFile(path.join(__dirname, 'json/json2.json'), 'utf8',function (err,data2) {
             if (err) throw err;
             // console.log(data2);
             data2 = JSON.parse(data2);
             ans = diff(data1, data2);
    
            // console.log(typeof ans);
            console.log(ans);
            let Str_ans = JSON.stringify(ans,null, 4);
            fs.writeFile('ret.json', Str_ans, 'utf8', (err) => {
                if (err) throw err;
                console.log('done');
            });
         });
    });
    
    

    注意readFile和readFileSync,writeFile和writeFileSync,后者是前者的同步版。
    但是一开始写入的json格式巨丑:
    这里写图片描述

    后来查到stringify的API才知道格式化输出。

    JSON.stringify(value[, replacer [, space]])

    参数

    • value
      将要序列化成 一个JSON 字符串的值。
    • replacer 可选
      如果该参数是一个函数,则在序列化过程中,被序列化的值的每个属性都会经过该函数的转换和处理;如果该参数是一个数组,则只有包含在这个数组中的属性名才会被序列化到最终的 JSON 字符串中;如果该参数为null或者未提供,则对象所有的属性都会被序列化;关于该参数更详细的解释和示例,请参考使用原生的 JSON 对象一文。
    • space 可选
      指定缩进用的空白字符串,用于美化输出(pretty-print);如果参数是个数字,它代表有多少的空格;上限为10。该值若小于1,则意味着没有空格;如果该参数为字符串(字符串的前十个字母),该字符串将被作为空格;如果该参数没有提供(或者为null)将没有空格。

    返回值 一个表示给定值的JSON字符串。

  • 相关阅读:
    Web项目管理工具精选(上)
    Web应用扩展系列(1):架构篇(转)
    Python高级特性(3): Classes和Metaclasses(转)
    Python高级特性(2):Closures、Decorators和functools(转)
    Python高级特性(1):Iterators、Generators和itertools(转)
    浅谈 Gevent 与 Tornado(转)
    使用gevent提高IO繁忙型wsgi服务的并发量(转)
    Python高级编程技巧(转)
    Python性能鸡汤(转)
    python采用pika库使用rabbitmq总结,多篇笔记和示例(转)
  • 原文地址:https://www.cnblogs.com/zhangmingzhao/p/8522791.html
Copyright © 2011-2022 走看看