使用dom和DocumentBuilder解析xml时遇到一些麻烦.我能够让它工作,但我想我对所有子节点等有点困惑.
这是我正在使用的XML:
Heparin effect
Acquired hemophilia
Acquired vWD
DIC
Dysfibrinogenemia
FI deficiency
FII deficiency
FII/IIa inhibitors
FIX deficiency
FIX inhibitors
FV deficiency
FV inhibitors
FVIII deficiency
FX deficiency
FX inhibitors
FXI deficiency
FXI inhibitors
FXII deficiency
FXII inhibitors
Heparin effect
Liver disease effect
Lupus anticoagulant
Monoclonal gammopathy
Vitamin K deficiency
vWD type 1
vWD type 2
vWD type 3
Warfarin effect
DIC
Dysfibrinogenemia
FVII deficiency
FXIII deficiency
FVII inhibitors
Liver disease effect
Lupus anticoagulant
Monoclonal gammopathy
Vitamin K deficiency
vWD type 1
vWD type 2
vWD type 3
Warfarin effect
DIC
我想要做的是抓住每个LabTest元素,并在每个元素中抓住值元素(并获取类型的值),并在值元素内抓住所有条件元素.
最后,我需要类似Map< String,HashMap< String,ArrayList< String>> ;,其中String是LabTest名称,HashMap使用键的类型(例如减少,增加等)然后使用该值类型的条件填充ArrayList.
足够困惑?
基本上,我只需要一个例子,我想,如何循环并抓住每个LabTest及其“值”元素,以及这些“值”元素下的每个“条件”元素.
解决方法:
这应该像你描述的那样工作:
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document doc = builder.parse("input.xml");
NodeList labTestList = doc.getElementsByTagName("LabTest");
for (int i = 0; i < labTestList.getLength(); ++i)
{
Element labTest = (Element) labTestList.item(i);
String labTestType = labTest.getAttribute("type");
NodeList valueList = labTest.getElementsByTagName("value");
for (int j = 0; j < valueList.getLength(); ++j)
{
Element value = (Element) valueList.item(j);
String valueType = value.getAttribute("type");
NodeList conditionList = value.getElementsByTagName("condition");
for (int k = 0; k < conditionList.getLength(); ++k)
{
Element condition = (Element) conditionList.item(k);
String conditionText = condition.getFirstChild().getNodeValue();
}
}
}
标签:java,dom,xml
来源: https://codeday.me/bug/20191004/1853145.html