Java:JSONObject.put循环给出了错误的顺序?

时间:2018-10-22 14:17:03

标签: java json

今天,我开始为日志文件编写一个简单的解析器。我想获取日志文件并将其转换为简单的json结构。

该日志文件是一致的,并且包含3个主要部分(下面的示例):

  • 时间戳[23位数字]
  • 代码[4位数字]
  • 有效载荷[可变数字]

示例日志

2018-07-25T08:47:16,094,164f,test1
2018-07-25T08:47:18,163,1678,test2
2018-07-25T08:47:19,501,1662,test3
2018-07-25T08:47:21,278,1634,test4
2018-07-25T08:47:23,347,1632,test5
2018-07-25T08:47:24,686,1665,test6
2018-07-25T08:47:26,463,1678,test7
2018-07-25T08:47:28,533,1678,test8
2018-07-25T08:47:29,877,1632,test9
2018-07-25T08:47:31,687,1632,test10

由此,我想创建一个JSON文件,该文件将内部的信息很好地结合在一起。这就是我想出的(使用org.json.JSONObject库)。

BufferedReader reader = new BufferedReader(new FileReader ("file.log"));

String line = null;
String timestamp = null;
String eventCode = null;
String payload = null;

JSONObject codePayload = new JSONObject();
JSONObject finalString = new JSONObject();

for (int i = 0; i < 10; i++) {
    line = reader.readLine();

    timestamp = line.substring(0, 23);
    eventCode = line.substring(24, 28);
    payload = line.substring(29, line.length());

    codePayload.put("ID", eventCode);
    codePayload.put("PL", payload);
    finalString.put(timestamp, codePayload);

    codePayload = new JSONObject();
  }
  System.out.println(finalString.toString());

这个小片段应该可以很好地工作(不要介意),而且确实可以。它根据我给它的字符串创建JSON文件,但随后以奇怪的顺序放置它,如下所示。

{
  "2018-07-25T08:47:24,686": {
    "ID": "1665",
    "PL": "test6"
  },
  "2018-07-25T08:47:29,877": {
    "ID": "1632",
    "PL": "test9"
  },
  "2018-07-25T08:47:31,687": {
    "ID": "1632",
    "PL": "test10"
  },
  "2018-07-25T08:47:16,094": {
    "ID": "164f",
    "PL": "test1"
  },
  "2018-07-25T08:47:21,278": {
    "ID": "1634",
    "PL": "test4"
  },
  "2018-07-25T08:47:18,163": {
    "ID": "1678",
    "PL": "test2"
  },
  "2018-07-25T08:47:23,347": {
    "ID": "1632",
    "PL": "test5"
  },
  "2018-07-25T08:47:28,533": {
    "ID": "1678",
    "PL": "test8"
  },
  "2018-07-25T08:47:19,501": {
    "ID": "1662",
    "PL": "test3"
  },
  "2018-07-25T08:47:26,463": {
    "ID": "1678",
    "PL": "test7"
  }
}

您可以清楚地看到它以错误的顺序放置了对象,我真的不知道为什么。如果有人对如何发生此问题有丝毫想法,请在下面评论。非常感谢!

1 个答案:

答案 0 :(得分:2)

org.json.JSONObject是无序的,因此最好使用javax.json.JSONObject。或者,如果您使用的是org.json库,请使用org.json.JSONArray按顺序存储时间戳。