使用java进行语义json数组比较

时间:2018-03-16 00:03:26

标签: java json

是否有内置的库或代码可以帮助我在语义上比较两个json数组:

我正在运行单元测试并且必须比较两个json数组并查看它们是否相等

Json Array1 =

[{"job_name":"CE","role_name":"Excellence"},
{"job_name":"PA","role_name":"Approver"},
{"job_name":"RO","role_name":"Financial"},
{"job_name":"RP","role_name":"Publisher"},
{"job_name":"SA","role_name":"Analyst"},
{"job_name":"TS","role_name":"Supervisor"},
{"job_name":"TT","role_name":"test"},
{"job_name":"ZG","role_name":"Manager"},
{"job_name":"ZI","role_name":"Manager"},
{"job_name":"ZJ","role_name":"Manager"}]

Json Array2:

{"role_name":"Excellence","job_name":"CE"},
{"role_name":"Approver","job_name":"PA"},
{"role_name":"Financial","job_name":"RO"},
{"role_name":"Publisher","job_name":"RP"},
{"role_name":"Analyst","job_name":"SA"},
{"role_name":"Supervisor","job_name":"TS"},
{"role_name":"test","job_name":"TT"},
{"role_name":"Manager","job_name":"ZG"},
{"role_name":"Manager","job_name":"ZI"},
{"role_name":"Manager","job_name":"ZJ"}

当我使用http://www.jsondiff.com/比较它时,它返回两个文件在语义上相同。

对于Java代码,我尝试使用以下两个库:

JSONCompareResult result = JSONCompare.compareJSON(Array1, Array1, 
JSONCompareMode.STRICT) :

JSONCompareResult result = JSONCompare.compareJSON(Array1, Array1, 
JSONCompareMode.LENIENT) :

另外,我尝试使用JSON断言:     JSONAssert.assertEquals(Array1,Array1,false);

但在这两种情况下,库都将JSON数组标记为不同。

非常感谢任何帮助或建议。

2 个答案:

答案 0 :(得分:0)

对于你想要的东西,这可能是漫长的啰嗦,我不知道任何捷径,所以我倾向于尝试解决它。 你需要检查数组长度相等,订购相同等... 但它可能会帮助某人......

import org.json.JSONArray;
import org.json.JSONObject;

public class ClassCompareTwoJsonArrays {

private static String JSONArray1 = "[{\"job_name\":\"CE\",\"role_name\":\"Excellence\"},"
        + "{\"job_name\":\"PA\",\"role_name\":\"Approver\"},"
        + "{\"job_name\":\"RO\",\"role_name\":\"Financial\"},"
        + "{\"job_name\":\"RP\",\"role_name\":\"Publisher\"},"
        + "{\"job_name\":\"SA\",\"role_name\":\"Analyst\"},"
        + "{\"job_name\":\"TS\",\"role_name\":\"Supervisor\"},"
        + "{\"job_name\":\"TT\",\"role_name\":\"Test1\"},"
        + "{\"job_name\":\"ZG\",\"role_name\":\"Manager\"},"
        + "{\"job_name\":\"ZI\",\"role_name\":\"Manager\"},"
        + "{\"job_name\":\"ZJ\",\"role_name\":\"Manager\"}]";

private static String JSONArray2 = "{\"role_name\":\"Excellence\",\"job_name\":\"CE\"},"
        + "{\"role_name\":\"Approver\",\"job_name\":\"PA\"},"
        + "{\"role_name\":\"Financial\",\"job_name\":\"RO\"},"
        + "{\"role_name\":\"Publisher\",\"job_name\":\"RP\"},"
        + "{\"role_name\":\"Analyst\",\"job_name\":\"SA\"},"
        + "{\"role_name\":\"Supervisor\",\"job_name\":\"TS\"},"
        + "{\"role_name\":\"Test1\",\"job_name\":\"TT\"},"
        + "{\"role_name\":\"Manager\",\"job_name\":\"ZG\"},"
        + "{\"role_name\":\"Manager\",\"job_name\":\"ZI\"},"
        + "{\"role_name\":\"Manager\",\"job_name\":\"ZJ\"}";


public static void main(String[] args) {

    //Array1 is set out like an array enclosed in []
    //Array2 is not so...
    JSONArray2 = "[" +JSONArray2 +"]";


    //Modify Array1 to allow JSON to read array by giving the array a name
    //Possibly an unneccesary work around - Self taught...
    JSONArray1 = "{Test1:{JSONArray1:" +JSONArray1 +"}}";
    JSONObject objAll =  new JSONObject(JSONArray1); 
    JSONObject objTest1 = objAll.getJSONObject("Test1");
    JSONArray arrJSONArray1 = objTest1.getJSONArray("JSONArray1");


    //Modify Array1 to allow JSON to read array by giving the array a name
    //Possibly an unneccesary work around - Self taught...
    JSONArray2 = "{Test2:{JSONArray2:" +JSONArray2 +"}}";
    JSONObject objAll2 =  new JSONObject(JSONArray2); 
    JSONObject objTest2 = objAll2.getJSONObject("Test2");
    JSONArray arrJSONArray2 = objTest2.getJSONArray("JSONArray2");


    // Initilise counts for record check results
    int FoundTheSame = 0;
    int FoundDifferent = 0;


    //Read Arrays and compare - code assumes arrays are the same length and order of records
    for (int i = 0; i < arrJSONArray1.length(); ++i) 
    {

        //Read data from Array1 for comparison
        JSONObject objTestJSONArray1 = arrJSONArray1.getJSONObject(i);
        String JSONArray1Job = objTestJSONArray1.getString("job_name");
        String JSONArray1Role = objTestJSONArray1.getString("role_name");

        //Read data from Array2 for comparison
        JSONObject objTestJSONArray2 = arrJSONArray2.getJSONObject(i);
        String JSONArray2Job = objTestJSONArray2.getString("job_name");
        String JSONArray2Role = objTestJSONArray2.getString("role_name");


        //Compare arrays and show results
        if (JSONArray1Job.equals(JSONArray2Job) && JSONArray1Role.equals(JSONArray2Role))
        {  // The same
            FoundTheSame = FoundTheSame + 1;
        } else {
            //Different
            FoundDifferent = FoundDifferent + 1;
            System.out.println("Error" + " " +FoundDifferent +", "
            +"Array Index (starts at 0) = " +i +", Array1 = " +JSONArray1Job +" "
            + JSONArray1Role +", Array2 = " +JSONArray2Job +", " + JSONArray2Role);

        }//end if
    }//end for

    System.out.println("Records found to be the same = " +FoundTheSame + " of " +arrJSONArray1.length());

}//end main
}//end class

当它们相同时会产生以下结果 - 与您提供的数据相同......

Records found to be the same = 10 of 10

或者,如果我更改某些内容以突出显示错误,则示例响应为...

Error 1, Array Index (starts at 0) = 4, Array1 = SA Analyst, Array2 = SA, Analystt
Error 2, Array Index (starts at 0) = 8, Array1 = AA Manager, Array2 = ZI, Manager
Records found to be the same = 8 of 10

答案 1 :(得分:0)

我建议您使用https://github.com/eBay/json-comparison库 这是测试这两个代码在语义上都相同的代码(我只是在数组中使用了前两行)BTW与此库一起,您还可以忽略特定的路径/过滤器路径/具有真正友好输出的命令来检出

ExtendedWord