Java处理xml

发布于:2024-05-19 ⋅ 阅读:(188) ⋅ 点赞:(0)

DOM(Document Object Model)

Java的DOM(Document Object Model)解析器是一种用于处理XML文档的API。允许Java程序解析XML文档并在内存中表示为树形结构,从而使得程序可以轻松地访问、修改和操作XML文档中的元素和属性。

读取

readXML接受一个字符串参数 filePath,该参数指定要读取的XML文件的路径。函数首先创建一个 DocumentBuilder 对象,并使用它来解析XML文件。然后,它遍历XML文档中所有的 元素,并提取每个元素的 id、name 和 price 属性值,并将它们打印到控制台上

public static void readXML(String filePath) {
        try {
            // 创建解析器工厂和解析器
            DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
            DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();

            // 解析XML文件
            File inputFile = new File(filePath);
            Document doc = dBuilder.parse(inputFile);
            doc.getDocumentElement().normalize();

            // 获取所有item节点的列表
            NodeList itemList = doc.getElementsByTagName("item");

            // 遍历item节点列表
            for (int i = 0; i < itemList.getLength(); i++) {
                Node itemNode = itemList.item(i);
                if (itemNode.getNodeType() == Node.ELEMENT_NODE) {
                    Element itemElement = (Element) itemNode;

                    // 获取item元素的id属性值
                    String id = itemElement.getAttribute("id");

                    // 获取name元素的文本内容
                    String name = itemElement.getElementsByTagName("name").item(0).getTextContent();

                    // 获取price元素的文本内容
                    String price = itemElement.getElementsByTagName("price").item(0).getTextContent();

                    // 打印item信息
                    System.out.println("Item ID: " + id);
                    System.out.println("Name: " + name);
                    System.out.println("Price: " + price);
                    System.out.println();
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

写入

writeXML接受四个参数:filePath 是要写入的XML文件的路径,id、name 和 price 分别是新item元素的属性值和内容。函数首先使用 DocumentBuilder 对象解析指定的XML文件,并获取到文档对象 doc。然后创建一个新的 元素,并设置其属性和子元素。接着将新的 元素添加到文档的根元素中,并将修改后的文档写回到原始的XML文件中

public static void writeXML(String filePath, String id, String name, String price) {
        try {
            // 创建解析器工厂和解析器
            DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
            DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();

            // 解析XML文件
            File inputFile = new File(filePath);
            Document doc = dBuilder.parse(inputFile);
            doc.getDocumentElement().normalize();

            // 创建新的item元素
            Element newItem = doc.createElement("item");
            newItem.setAttribute("id", id);

            // 创建name元素并添加文本内容
            Element nameElement = doc.createElement("name");
            nameElement.appendChild(doc.createTextNode(name));

            // 创建price元素并添加文本内容
            Element priceElement = doc.createElement("price");
            priceElement.appendChild(doc.createTextNode(price));

            // 将name和price元素添加到item元素中
            newItem.appendChild(nameElement);
            newItem.appendChild(priceElement);

            // 将新的item元素添加到根元素中
            doc.getDocumentElement().appendChild(newItem);

            // 将修改后的文档写入原始XML文件
            TransformerFactory transformerFactory = TransformerFactory.newInstance();
            Transformer transformer = transformerFactory.newTransformer();
            DOMSource source = new DOMSource(doc);
            StreamResult result = new StreamResult(new File(filePath));
            transformer.transform(source, result);

            System.out.println("XML文件写入成功。");

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

参考文献

Java DOM 教程


网站公告

今日签到

点亮在社区的每一天
去签到