gpt4 book ai didi

java - Digester XML 规则中的通配符

转载 作者:太空宇宙 更新时间:2023-11-04 08:48:48 24 4
gpt4 key购买 nike

我见过不同的线程讨论我遇到的此类问题。以下是一些:http://www.mailinglistarchive.com/commons-user@jakarta.apache.org/msg05061.html , Digester: Extracting node name )。

但是,我仍然找不到解决这个问题的方法。这是我的 XML 数据:

<rows>
<row>
<firstname>Paul</firstname>
<lastname>Moris</lastname>
</row>
<row>
<firstname>John</firstname>
<lastname>Aiyer</lastname>
<age>35</age>
</row>
</rows>

我想要的是定义 XML 规则,允许我将每一行映射到一个映射中。我无法通过引用元素的名称来映射元素,因为并非所有可能的元素都是预先知道的。

我希望这样的事情能让我做到这一点:

<digester-rules>
<pattern value="rows/row">
<object-create-rule classname="Address"/>
<set-next-rule methodname="add" paramtype="java.lang.Object"/>
<set-properties-rule/>

<pattern value="*">
<call-method-rule methodname="set" paramcount="2"/>
<call-param-rule paramnumber='0'/>
<call-param-rule paramnumber='1'/>
</pattern>
</pattern>
</digester-rules>

地址的实现是:

public class Address {
Map<String,String> c= new HashMap<String,String>();

public void set(String name, String value){
c.put(name, value);
}

public String toString(){
return c.toString();
}
}

不幸的是,当我运行此代码时,我得到了两个已创建的地址,但底层 map 为空。当我使用 ExtendedBaseRules 时,甚至没有任何匹配。

任何帮助将不胜感激。

最大。

最佳答案

我认为 Digester 在解析遗留 xml 方面并不擅长。但幸运的是,它具有足够的可扩展性,可以对其进行调整以在某些情况下工作。

我仅通过使用 java api 解决了这个问题,而不是使用 xml 规则。使用 Digester 的 ExtendedBaseRules 类非常重要,以便匹配模式 rows/row/* 并子类化标准 CallParamRule,以便将标记名称作为第一个参数传递给类 Address 的方法 addAddressLine()(我将类 Address 中的方法 set() 重命名为 addAddressLine())。

Digester digester = new Digester();         
digester.setRules(new ExtendedBaseRules());
digester.setValidating( false );
digester.addObjectCreate("rows", Addresses.class);
digester.addObjectCreate( "rows/row", Address.class );
digester.addSetNext( "rows/row", "add");
digester.addSetProperties("rows/row");
digester.addCallMethod("rows/row/*", "addAddressLine", 2);
digester.addRule("rows/row/*", new TagNameAwarePathCallParamRule(0));
digester.addCallParam("rows/row/*", 1);
Addresses addresses = (Addresses) digester.parse(new File(FILE_TO_PARSE));

我为此目的实现的类 TagNameAwarePathCallParamRule:

public class TagNameAwarePathCallParamRule extends CallParamRule {

public TagNameAwarePathCallParamRule(int paramIndex) {
super(paramIndex);
}

public void end(String namespace, String name) {
if (bodyTextStack != null && !bodyTextStack.empty()) {
// what we do now is push one parameter onto the top set of
// parameters
Object parameters[] = (Object[]) digester.peekParams();
parameters[paramIndex] = name;
}

}
}

我用于存储解析输出的类:

public class Addresses {

private List<Address> addresses = new ArrayList<Address>();

public void add(Address a) {
addresses.add(a);
}

public List<Address> getAddresses() {
return Collections.unmodifiableList(addresses);
}

public String toString() {
StringBuilder sb = new StringBuilder();
for (Address a : addresses) {
sb.append("Address: ").append(a.toString()).append(',');
}
return sb.toString();
}
}


public class Address {
Map<String,String> c= new HashMap<String,String>();


public void addAddressLine(String name, String value){
c.put(name, value);
}

public String toString(){
return c.toString();
}
}

关于java - Digester XML 规则中的通配符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3817125/

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