【问题标题】:Converting flatfile to JSON in Java在 Java 中将平面文件转换为 JSON
【发布时间】:2021-01-26 15:18:04
【问题描述】:

我需要将平面文件转换为 Java 中的 JSON 文件。

我的平面文件如下所示:

customerInfo.firstName=abc
customerInfo.lastName=aaa
customerInfo.nickNames.0.name=bbb
customerInfo.nickNames.0.meaning=ccc

这是我正在使用的一段代码:

JSONParser parser = new JSONParser();
Object obj = null;
try {
    //obj = parser.parse(new FileReader("src/main/resources/flatfileex.txt"));
    JSONObject jsonObject = (JSONObject) parser.parse(new InputStreamReader(new FileInputStream("src/main/resources/flatfileex.txt")));;
    String flattenedJson = JsonFlattener.flatten(jsonObject.toJSONString());
    System.out.println(flattenedJson);
} catch (FileNotFoundException | IOException | ParseException e) {
    e.printStackTrace();
}

我在上面的代码中使用了 jsonflattener 依赖:

<dependency>
    <groupId>com.github.wnameless</groupId>
    <artifactId>json-flattener</artifactId>
    <version>0.1.0</version>
</dependency>

解析文件时出现错误,位置 0 出现意外字符 [c]。如何解决?

【问题讨论】:

  • 抱歉,您的输入不是 json。为什么要使用 JSON 解析器来读取非 json 输入?那是纯文本。您需要根据嵌入到文本文件中专有“格式”中的“语义”编写代码来解析它。然后你可以从这些对象创建 JSONObjects,并将它们写为 JSON。
  • @GhostCat 有什么方法可以将平面文件转换为 json,然后将文本文件转换为 json,而无需使用 objectmapper 和一些骨架对象模式?
  • 如果你有一个 FlatFile,你可以用 jFFP 之类的东西解析它,然后用 Jackson 或其他东西序列化它以获得 JSON,但你没有 FlatFile。你有一些奇怪的属性集,所以首先想到的是java.util.Properties,但是你最终会得到名为0 的变量,这在Java 中是不可能的,因为命名约定。长话短说,您的输入数据是垃圾,这正是以 XML 或 JSON 等格式交换数据的原因,以避免解析无意义的数据。您可能必须为反序列化编写自定义解析器。
  • 然后,当您的输入具有正确的 Java 对象表示时,您可以进行下一步,即序列化为 JSON。

标签: java json flat-file


【解决方案1】:

您的输入文件看起来像一个 Java 属性文件,因此您可以试试这个:

Properties prop = new Properties();
try (InputStream inputStream = Thread.currentThread().getContextClassLoader().getResourceAsStream("content.txt")){
    prop.load(inputStream);
    String contentAsJson = new ObjectMapper().writeValueAsString(prop);
    System.out.print(contentAsJson);
} catch (IOException exception) {
    System.out.println("Something went wrong!");
}

如果您的文件包含

customerInfo.firstName=abc
customerInfo.lastName=aaa
customerInfo.nickNames.0.name=bbb
customerInfo.nickNames.0.meaning=ccc

它会打印出来

{"customerInfo.lastName":"aaa","customerInfo.firstName":"abc","customerInfo.nickNames.0.name":"bbb","customerInfo.nickNames.0.meaning":"ccc"}

我猜你可以从这里使用json-flattener

【讨论】:

  • 名为0 的变量呢?一旦你将它反序列化为它所代表的对象,它就会爆炸。如果您想采用这种方式,它已经需要作为数组存储在 JSON 中,以免以后出现问题。
  • customerInfo.nickNames.0.name 我想将其转换为 json 数组而不是属性
  • 他们真的想要一个 POJO 来代表这个吗? AFAIT 的问题是如何将该输入转换为 JSON。
  • 哦,看起来你想要的是 unflatten 你的 JSON。你可以使用JsonUnflattener.unflatten
  • unflatten 可以解决问题,如果您在 contentAsJson 每个正则表达式 \.(\d+)\ 中替换。与 [$1]。
猜你喜欢
  • 2012-09-08
  • 1970-01-01
  • 2010-11-20
  • 2017-11-22
  • 2019-06-20
  • 2018-08-20
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多