我已将 XML 文档读入 JAVA DOM 数据结构。我可以使用 For 循环搜索文档并查找信息。然后我可以将父节点和子节点中保存的所有信息打印到终端。
但是,我需要做的是获取某些元素并将它们打印到电子表格中。因此,以某种方式将值写入 csv 文档,然后我可以将其导入 Excel。
这将为我节省大量时间,因为我必须手动将值复制到电子表格中,这需要我花费数周时间。所以自动化它是最好的选择,但我在 Java 方面缺乏经验。任何帮助表示赞赏。
我已将 XML 文档读入 JAVA DOM 数据结构。我可以使用 For 循环搜索文档并查找信息。然后我可以将父节点和子节点中保存的所有信息打印到终端。
但是,我需要做的是获取某些元素并将它们打印到电子表格中。因此,以某种方式将值写入 csv 文档,然后我可以将其导入 Excel。
这将为我节省大量时间,因为我必须手动将值复制到电子表格中,这需要我花费数周时间。所以自动化它是最好的选择,但我在 Java 方面缺乏经验。任何帮助表示赞赏。
使用单个 DOM 解析器实例执行此操作可能非常麻烦。为此,我建议创建一个包含 xml 文件中所有数据的 JavaBean。调用该类的一个简单方法toCsv
将遍历所有项目并返回格式化的内容或将其打印到 csv 文件。如果您遵循这种方法,您可以简单地使用Java Architecture for XML Binding (JAXB)
which 将为您在 XML 和 Java 对象之间进行编组和解组。不再需要可能难以维护的自定义 DOM 解析器实现。JAXB 与定义解析器规则的注释一起工作。这是一个简单的例子:
public interface DataEntity {
/**
* NameSpace of XSD schema files.
*/
public final static String NSP = "https://localhost/project/xsd/";
}
import java.io.Serializable;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
import at.fhj.ase.dao.data.validation.ValidationHelper;
/**
* Represents a product category
*
*/
@XmlRootElement(name = "category", namespace = DataEntity.NSP)
public class Category implements Serializable {
/**
*
*/
private static final long serialVersionUID = -487248720383832971L;
private Integer id;
private String name;
private String description;
protected Category() {
}
public Category(final Integer id, final String name,
final String description) {
setId(id);
setName(name);
setDescription(description);
}
@XmlAttribute
public Integer getId() {
return id;
}
private void setId(Integer id) {
ValidationHelper.validateId(id);
this.id = id;
}
@XmlElement(namespace = DataEntity.NSP)
public String getName() {
return name;
}
private void setName(String name) {
ValidationHelper.validateSingleName(name, "name");
this.name = name;
}
@XmlElement(namespace = DataEntity.NSP)
public String getDescription() {
return description;
}
private void setDescription(String description) {
ValidationHelper.validateSingleName(description, "description");
this.description = description;
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("Id: ").append(id).append(" Name: ").append(getName())
.append(" Description: ").append(description);
return sb.toString();
}
}
并将 xml 文件作为输入:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<category xmlns="https://localhost/project/xsd/" id="1">
<description>des_swdevelopment</description>
<name>swdevelopment</name>
</category>
以及如何从 xml 解组到 java: Interface Unmarshaller
您只需要添加toCsv
方法即可。这种方法将为您节省大量时间,并且非常易于维护。