要獲取XML標簽里面的值,可以使用Java中的DOM或SAX解析器。
使用DOM解析器:
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document doc = builder.parse("file.xml");
Element root = doc.getDocumentElement();
NodeList nodeList = root.getElementsByTagName("tagName");
for (int i = 0; i < nodeList.getLength(); i++) {
Node node = nodeList.item(i);
if (node.getNodeType() == Node.ELEMENT_NODE) {
Element element = (Element) node;
String value = element.getTextContent();
// 處理獲取到的值
}
}
使用SAX解析器:
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.Attributes;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser parser = factory.newSAXParser();
DefaultHandler handler = new DefaultHandler() {
// 重寫startElement方法
@Override
public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
// 判斷當前的標簽名是否是要獲取值的標簽
if (qName.equals("tagName")) {
// 處理獲取到的值
}
}
};
parser.parse(new InputSource("file.xml"), handler);
需要根據具體的XML結構和需求來選擇使用DOM還是SAX解析器。