java解析xml文件

1.Dom解析xml

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import java.io.File;
import java.io.IOException;
import java.util.Arrays;

/**
 * @ClassName Xml
 * @Description :使用DOM进行解析XML
 */

public class Xml {
    public static void main(String[] args) throws ParserConfigurationException, IOException, SAXException {
        //DocumentBuilder类的构造函数是受保护的,不能直接实例化
        //使用静态工厂方法来进行创建建符合标准的DocumentBuilder实例
        DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
        DocumentBuilder builder = factory.newDocumentBuilder();
        Document document = builder.parse(new File("E:\\code\\Java\\01_java基础\\src\\test.xml"));
        // 获取XML文档的根元素
        Element rootElement = document.getDocumentElement();
        // 打印根元素的标签名
        System.out.println("Root element: " + rootElement.getNodeName());
        NodeList childNodes = rootElement.getChildNodes();
        for (int i = 0; i < childNodes.getLength(); i++) {
            //获取元素,此包含了文本元素以及节点元素
            Node node = childNodes.item(i);
            System.out.println(node);
            if (node.getNodeType() ==Node.ELEMENT_NODE){
                Element element = (Element) node;
//                打印元素节点的标签名和文本内容
                System.out.println("下面开始了-----------");
                System.out.println("Element"+element.getNodeName());
                System.out.println("content"+element.getTextContent());

            }

        }


    }
}

2.SAX解析

import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.InputSource;

public class Main {
    public static void main(String[] args) {
        try {
            // 创建 SAXParserFactory 实例
            SAXParserFactory factory = SAXParserFactory.newInstance();
            
            // 创建 SAXParser 实例
            SAXParser parser = factory.newSAXParser();
            
            // 创建 MyContentHandler 实例
            MyContentHandler contentHandler = new MyContentHandler();
            
            // 解析 XML 文档
            String xml = "<root><element attr=\"value\">Text</element></root>";
            parser.parse(new InputSource(new StringReader(xml)), contentHandler);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;

public class MyContentHandler extends DefaultHandler {
    
    @Override
    public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
        // 处理元素开始标签事件
        System.out.println("Start Element: " + qName);
        
        // 如果有属性,处理属性
        if (attributes.getLength() > 0) {
            System.out.println("Attributes:");
            for (int i = 0; i < attributes.getLength(); i++) {
                System.out.println(attributes.getQName(i) + "=" + attributes.getValue(i));
            }
        }
    }
    
    @Override
    public void endElement(String uri, String localName, String qName) throws SAXException {
        // 处理元素结束标签事件
        System.out.println("End Element: " + qName);
    }
    
    @Override
    public void characters(char[] ch, int start, int length) throws SAXException {
        // 处理文本节点事件
        String text = new String(ch, start, length).trim();
        if (!text.isEmpty()) {
            System.out.println("Text: " + text);
        }
    }
}

MyContentHandler类继承自DefaultHandler,是一个自定义的内容处理器。在该类中重写了startElement()、endElement()和characters()方法,以处理XML解析的不同事件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 下面是 Java 解析 XML 文件的核心代码: ``` import java.io.File; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.NodeList; public class Main { public static void main(String[] args) { try { File xmlFile = new File("example.xml"); DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance(); DocumentBuilder dBuilder = dbFactory.newDocumentBuilder(); Document doc = dBuilder.parse(xmlFile); System.out.println("Root element :" + doc.getDocumentElement().getNodeName()); NodeList nList = doc.getElementsByTagName("student"); System.out.println("----------------------------"); for (int temp = 0; temp < nList.getLength(); temp++) { org.w3c.dom.Node nNode = nList.item(temp); System.out.println("\nCurrent Element :" + nNode.getNodeName()); if (nNode.getNodeType() == org.w3c.dom.Node.ELEMENT_NODE) { org.w3c.dom.Element eElement = (org.w3c.dom.Element) nNode; System.out.println("Student roll no : " + eElement.getAttribute("rollno")); System.out.println("First Name : " + eElement.getElementsByTagName("firstname").item(0).getTextContent()); System.out.println("Last Name : " + eElement.getElementsByTagName("lastname").item(0).getTextContent()); System.out.println("Nick Name : " + eElement.getElementsByTagName("nickname").item(0).getTextContent()); System.out.println("Marks : " + eElement.getElementsByTagName("marks").item(0).getTextContent()); } } } catch (Exception e) { e.printStackTrace(); } } } ``` 在上面的代码中,我们使用了 DocumentBuilder 类来解析 XML 文件。首先,我们创建了一个 DocumentBuilder 对象,然后使用它的 parse() 方法来解析 XML 文件。最后,我们遍历 XML 文件中的所有节点,并打印出它们的内容。 ### 回答2: Java解析XML文件的核心代码通常使用javax.xml.parsers包中的DOM解析器或SAX解析器。下面是这两种解析方式的核心代码示例: 1. 使用DOM解析器: ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; import org.w3c.dom.Document; import org.w3c.dom.NodeList; import org.w3c.dom.Node; public class XMLParser { public static void main(String[] args) { try { // 创建DOM解析器工厂 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); // 创建DOM解析器 DocumentBuilder builder = factory.newDocumentBuilder(); // 解析XML文件,返回Document对象 Document document = builder.parse("file.xml"); // 获取指定节点的值 NodeList nodeList = document.getElementsByTagName("element"); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); System.out.println(node.getTextContent()); } } catch (Exception e) { e.printStackTrace(); } } } ``` 2. 使用SAX解析器: ```java import org.xml.sax.Attributes; import org.xml.sax.SAXException; import org.xml.sax.helpers.DefaultHandler; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; public class XMLParser { public static void main(String[] args) { try { // 创建SAX解析器工厂 SAXParserFactory factory = SAXParserFactory.newInstance(); // 创建SAX解析器 SAXParser parser = factory.newSAXParser(); // 创建自定义的事件处理器 MyHandler handler = new MyHandler(); // 解析XML文件 parser.parse("file.xml", handler); } catch (Exception e) { e.printStackTrace(); } } } class MyHandler extends DefaultHandler { @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { if (qName.equalsIgnoreCase("element")) { // 获取元素属性值 String attributeValue = attributes.getValue("attribute"); System.out.println(attributeValue); } } @Override public void characters(char[] ch, int start, int length) throws SAXException { // 获取元素文本内容 String text = new String(ch, start, length); System.out.println(text); } } ``` 以上代码分别演示了使用DOM解析器和SAX解析器来解析XML文件,并获取指定节点的值或属性值。实际使用时,可以根据具体需求进行适当的修改和扩展。 ### 回答3: Java解析XML文件的核心代码通常涉及以下步骤: 1. 创建一个DocumentBuilder对象,用于解析XML文件。 ```java DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); ``` 2. 通过DocumentBuilder对象解析XML文件,并返回一个表示整个文件的Document对象。 ```java Document document = builder.parse(new File("file.xml")); ``` 3. 从Document对象中获取根元素。 ```java Element root = document.getDocumentElement(); ``` 4. 通过根元素遍历XML文件的每个元素或节点。 ```java NodeList nodeList = root.getChildNodes(); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); // 进一步处理该节点的相关操作 } ``` 5. 对于每个节点,可以通过其标签名称、属性等获取相应的信息。 ```java if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; String tagName = element.getTagName(); String attributeValue = element.getAttribute("attributeName"); // 处理该元素或节点的相关操作 } ``` 6. 对于每个节点,还可以获取其文本内容。 ```java if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; String textContent = element.getTextContent(); // 处理该元素或节点的相关操作 } ``` 7. 另外,还可以使用XPath来解析XML文件,以简化代码和提高效率。可以通过XPath对象的evaluate()方法获取满足条件的节点列表。 ```java XPathFactory xPathFactory = XPathFactory.newInstance(); XPath xpath = xPathFactory.newXPath(); String expression = "//tagName"; NodeList nodeList = (NodeList) xpath.evaluate(expression, document, XPathConstants.NODESET); ``` 这些是Java解析XML文件的一些核心代码,可以根据具体的需求进行相应的扩展和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值