要获取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解析器。