gpt4 book ai didi

java 需要帮助从 CSV 替换 XML 标签内容

转载 作者:行者123 更新时间:2023-12-01 16:50:36 25 4
gpt4 key购买 nike

我正在尝试读取 csv 文件,并根据放置在 XML 标记之间的 CSV header ,将 xml 元素内容替换为 CSV 中的值。

toName,fromName,标题,正文约翰,埃尔维斯,标题内容,正文内容卡恩,猫王,标题内容,正文内容裘德,埃尔维斯,标题内容,正文内容

<note>
<to>{{toName}}</to>
<from>{{fromName}}</from>
<heading>{{heading}}</heading>
<body>{{body}</body>
</note>

有人可以建议如何做到这一点吗?

提前致谢。

最佳答案

看起来您可以使用 jackson mapper 来处理 xml 和 CSV

https://github.com/FasterXML/jackson-dataformats-text/tree/master/csv

<dependency>
<groupId>com.fasterxml.jackson.dataformat</groupId>
<artifactId>jackson-dataformat-csv</artifactId>
<version>2.8.8</version>
</dependency>

<dependency>
<groupId>com.fasterxml.jackson.dataformat</groupId>
<artifactId>jackson-dataformat-xml</artifactId>
<version>2.10.1</version>
</dependency>



ObjectMapper xmlMapper = new XmlMapper();
Simple value = xmlMapper.readValue("<Simple><x>1</x><y>2</y></Simple>", Simple.class);

// Schema from POJO (usually has @JsonPropertyOrder annotation)
CsvSchema schema = mapper.schemaFor(Pojo.class);

// Manually-built schema: one with type, others default to "STRING"
CsvSchema schema = CsvSchema.builder()
.addColumn("firstName")
.addColumn("lastName")
.addColumn("age", CsvSchema.ColumnType.NUMBER)
.build();

// Read schema from the first line; start with bootstrap instance
// to enable reading of schema from the first line
// NOTE: reads schema and uses it for binding
CsvSchema bootstrapSchema = CsvSchema.emptySchema().withHeader();
ObjectMapper mapper = new CsvMapper();
mapper.readerFor(Pojo.class).with(bootstrapSchema).readValue(json);

关于java 需要帮助从 CSV 替换 XML 标签内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61699063/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com