使用NodeList和DocumentBuilder解析Xml

使用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元素,并在每个元素中抓住value元素(并获取type的值),并在value元素内抓住所有condition元素。

最后,我想要一个像Map<String, HashMap<String, ArrayList> ,其中StringLabTest名称, HashMap使用键的type (例如decreasedincreased等),然后填充使用该value类型的条件启动ArrayList。

足够困惑?

基本上,我只需要一个例子,我想,如何循环并抓住每个LabTest及其“value”元素,以及这些“value”元素下的每个“condition”元素。

这应该像你描述的那样工作:

 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(); } } }