我有一个xml文件,如下所示:
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<RULES>
<RULE DESCRIPTION="" DOMAIN="CAE" NAME="Filter1 " TYPE="FILTER">
<ATTRS>
<ATTR RULE_NAME="myFilter1" />
</ATTRS>
</RULE>
<RULE DESCRIPTION="" DOMAIN="CAE" NAME="Skip1" TYPE="SKIP">
<ATTRS>
<ATTR RULE_NAME="mySkip1" />
</ATTRS>
</RULE>
<RULE DESCRIPTION="" DOMAIN="CAE" NAME="Filter_new " TYPE="FILTER">
<ATTRS>
<ATTR RULE_NAME="myFilter1" />
</ATTRS>
</RULE>
<RULE DESCRIPTION="" DOMAIN="CAE" NAME="Skip_new" TYPE="SKIP">
<ATTRS>
<ATTR RULE_NAME="mySkip1" />
</ATTRS>
</RULE>
</RULES>
如何使用SAXParser(在C ++中)解析此文件,以便仅当TYPE属性具有值“FILTER”时才能提取RULE_NAME属性的值。
我可以使用DOMParser执行此操作,但我想使用SAXParser。
答案 0 :(得分:1)
@Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
if (localName.equals("city")) {
String city = attributes.getValue("data");
info.setCity(city);
} else if (localName.equals("temp_c")) {
String t = attributes.getValue("data");
int temp = Integer.parseInt(t);
info.setTemp(temp);
} else if (localName.equals("condition")) {
String condition = attributes.getValue("data");
info.setCondition(condition);
}
}
您可以使用比较属性,因为我正在做“数据”,这是子属性。希望这项工作