Apache 配置 - 处理同名的多个 XML 条目
Apache Configurations - Handling Multiple XML entries of same name
所有 - 不确定我是否走在正确的轨道上,但这是我目前所掌握的。
我们有一个处理器需要遍历并处理我们在配置文件中指定的一系列文件。
XMLConfiguration config = new XMLConfiguration(CONFIG_FILE_DIR);
if (config != null) {
String filePath = config.getString("files.file.filepath");
String inputFile = config.getString("files.file.inputfile");
String outputFile = config.getString("files.file.outputfile");
String cellRange = config.getString("files.file.cellrange");
translateXLS(filePath, inputFile, outputFile, cellRange);
}
else {
System.out.println("CONFIG NOT SET");
}
翻译 XLS 方法效果很好,可以继续处理我们从配置文件中提供的任何文件。
当我们希望它处理 多个 文件时,我们遇到了一些问题,因为它只会获取最后一个条目并使用它。显然我没有任何循环机制或数组,所以这是有道理的,但我想知道我是否需要使用 XPath 或类似的东西来处理下面的示例配置:
<xml version="1.0" encoding="UTF-8">
<files>
<file>
<filepath>C:\sample\</filepath>
<inputfile>1.xls</inputfile>
<outputfile>1out.out</outputfile>
<cellrange>F1:I2</cellrange>
</file>
<file>
<filepath>C:\sample\</filepath>
<inputfile>2.xls</inputfile>
<outputfile>2out.out</outputfile>
<cellrange>A1:J2</cellrange>
</file>
</files>
</xml>
存储配置列表或配置数组之类的内容以循环遍历并对同一 config.xml 中的所有文件执行操作的最佳选择是什么?
我主要是参考这个。从技术上讲,我可以设置一些类似他们在这里使用的索引的东西,但我必须对我有多少条目进行硬编码。如果它足够灵活,可以遍历每个条目,那就太好了。
http://www.code-thrill.com/2012/05/configuration-that-rocks-with-apache.html
如果您不想有任何外部依赖项,则可以使用 JAXB。 JAXB 包含在 Java 6 及更高版本中。
首先创建一个代表 <file></file>
条目的 class:
public class FileEntry {
@XmlElement public String filepath;
@XmlElement public String inputfile;
@XmlElement public String outputfile;
@XmlElement public String cellrange;
}
然后创建一个class表示<files></files>
:
public class Config {
@XmlElement(name="file") public List<FileEntry> entries;
}
然后载入 XML:
public static void main(String[] args) throws JAXBException {
JAXBContext ctx = JAXBContext.newInstance(Config.class);
Unmarshaller um = ctx.createUnmarshaller();
JAXBElement<Config> element = um.unmarshal(new StreamSource(new File("config.xml")), Config.class);
Config config = element.getValue();
for (FileEntry file : config.entries) {
System.out.println(file.filepath);
System.out.println(file.inputfile);
System.out.println(file.outputfile);
System.out.println(file.cellrange);
}
}
并且您的 xml 文件的第一行应该是 <?xml version="1.0" encoding="UTF-8"?>
,末尾没有 </xml>
。
所有 - 不确定我是否走在正确的轨道上,但这是我目前所掌握的。
我们有一个处理器需要遍历并处理我们在配置文件中指定的一系列文件。
XMLConfiguration config = new XMLConfiguration(CONFIG_FILE_DIR);
if (config != null) {
String filePath = config.getString("files.file.filepath");
String inputFile = config.getString("files.file.inputfile");
String outputFile = config.getString("files.file.outputfile");
String cellRange = config.getString("files.file.cellrange");
translateXLS(filePath, inputFile, outputFile, cellRange);
}
else {
System.out.println("CONFIG NOT SET");
}
翻译 XLS 方法效果很好,可以继续处理我们从配置文件中提供的任何文件。
当我们希望它处理 多个 文件时,我们遇到了一些问题,因为它只会获取最后一个条目并使用它。显然我没有任何循环机制或数组,所以这是有道理的,但我想知道我是否需要使用 XPath 或类似的东西来处理下面的示例配置:
<xml version="1.0" encoding="UTF-8">
<files>
<file>
<filepath>C:\sample\</filepath>
<inputfile>1.xls</inputfile>
<outputfile>1out.out</outputfile>
<cellrange>F1:I2</cellrange>
</file>
<file>
<filepath>C:\sample\</filepath>
<inputfile>2.xls</inputfile>
<outputfile>2out.out</outputfile>
<cellrange>A1:J2</cellrange>
</file>
</files>
</xml>
存储配置列表或配置数组之类的内容以循环遍历并对同一 config.xml 中的所有文件执行操作的最佳选择是什么?
我主要是参考这个。从技术上讲,我可以设置一些类似他们在这里使用的索引的东西,但我必须对我有多少条目进行硬编码。如果它足够灵活,可以遍历每个条目,那就太好了。
http://www.code-thrill.com/2012/05/configuration-that-rocks-with-apache.html
如果您不想有任何外部依赖项,则可以使用 JAXB。 JAXB 包含在 Java 6 及更高版本中。
首先创建一个代表 <file></file>
条目的 class:
public class FileEntry {
@XmlElement public String filepath;
@XmlElement public String inputfile;
@XmlElement public String outputfile;
@XmlElement public String cellrange;
}
然后创建一个class表示<files></files>
:
public class Config {
@XmlElement(name="file") public List<FileEntry> entries;
}
然后载入 XML:
public static void main(String[] args) throws JAXBException {
JAXBContext ctx = JAXBContext.newInstance(Config.class);
Unmarshaller um = ctx.createUnmarshaller();
JAXBElement<Config> element = um.unmarshal(new StreamSource(new File("config.xml")), Config.class);
Config config = element.getValue();
for (FileEntry file : config.entries) {
System.out.println(file.filepath);
System.out.println(file.inputfile);
System.out.println(file.outputfile);
System.out.println(file.cellrange);
}
}
并且您的 xml 文件的第一行应该是 <?xml version="1.0" encoding="UTF-8"?>
,末尾没有 </xml>
。