xml文件基本格式与解析(一)

转载自:
https://blog.csdn.net/qq_38254978/article/details/77870598

XML文件创建格式

<?xml version="1.0" encoding="utf-8" ?>
<root>
    <part id = "01" name="选项一">
        <name>我是徐茅山</name>
        <age>今年20岁</age>
        <sex>男</sex>
    </part>
    <part id="02" name="选项二">
        <name>我是李逍遥</name>
        <age>今年22岁</age>
        <sex>男</sex>
    </part>
</root>

xml文件的解析

package com.xinsi.qi.utils;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;

import java.io.File;
import java.util.List;

public class Dom4jXml {
    public void test(){
        try {
            File inputFile = new File("F:\\J2EE学习资料\\demoLes03\\web\\WEB-INF\\test.xml");
            SAXReader reader = new SAXReader();
            Document document = reader.read(inputFile);
            System.out.println("Root element :"+document.getRootElement().getName());

            Element classElement = document.getRootElement();

            List<Node> nodes = document.selectNodes("/class/part[@id='02']");

            System.out.println("--------------------");

            for (Node node:nodes){
                System.out.println("标签名=:"+node.getName());
                System.out.println("姓名:"+node.selectSingleNode("name").getText());
                System.out.println("年龄:"+node.selectSingleNode("age").getText());
                System.out.println("性别:"+node.selectSingleNode("sex").getText());
            }
        } catch (Exception e1) {
            e1.printStackTrace();
        }
    }

}

List nodes = document.selectNodes(“/class/part[@id=’02’]”) 这段代码的意思是,定位到该元素属性的位置,使用该方法还需要下载,jaxen.jar包,jaxen的下载地址
@id=’02’的意思是定位到id为02的元素属性,以遍历的形式输出出来。

for (Node node:nodes){
System.out.println("标签名=:"+node.getName());
System.out.println("姓名:"+node.selectSingleNode("name").getText());
System.out.println("年龄:"+node.selectSingleNode("age").getText());
System.out.println("性别:"+node.selectSingleNode("sex").getText());
}

最终控制台的输出结果为:

标签名=:part
姓名:我是李逍遥
年龄:今年22岁
性别:男
  • 4
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 对于提供一个解析XML文件的代码,我可以提供以下示例代码:import xml.etree.ElementTree as ETtree = ET.parse('data.xml') root = tree.getroot()for item in root.findall('item'): print(item.find('name').text) print(item.find('price').text) ### 回答2: 解析XML文件的代码可以使用Python的xml.etree.ElementTree库来实现。以下是一个简单的示例代码: ```python import xml.etree.ElementTree as ET def parse_xml(xml_file): # 加载XML文件 tree = ET.parse(xml_file) # 获取根元素 root = tree.getroot() # 遍历根元素下的所有子元素 for child in root: # 输出子元素的标签和文本内容 print(child.tag, child.text) # 获取指定标签的所有元素 elements = root.findall('element_name') for element in elements: # 输出元素的属性和文本内容 for key, value in element.attrib.items(): print(key, value) print(element.text) # 修改元素的文本内容 element = root.find('element_name') element.text = 'new_text' # 删除指定的元素 element = root.find('element_name') root.remove(element) # 创建新的元素并添加到指定的位置 new_element = ET.Element('new_element') root.insert(0, new_element) # 保存修改后的XML文件 tree.write('output.xml') # 调用函数解析XML文件 parse_xml('input.xml') ``` 上述代码中,通过`ET.parse()`方法加载XML文件,然后使用`getroot()`获取根元素。使用`findall()`方法可以获取指定标签的所有元素,使用`find()`方法可以查找指定标签的第一个元素。可以通过遍历和索引的方式获取元素的属性和文本内容,并进行修改和删除操作。最后使用`write()`方法将修改后的XML内容保存到新的文件中。根据实际需求,可以根据上述代码进行修改和扩展。 ### 回答3: 解析XML文件是指将XML文件的内容转化为程序可以处理的数据结构。在实现解析XML文件的代码之前,我们需要先了解一些基本的概念。XML(可扩展标记语言)是一种用于表示结构化数据的标记语言,它由一系列的标签组成,每个标签包含一个元素以及该元素的属性和值。 以下是一个简单的示例,演示如何使用Java编写解析XML文件的代码: ```java import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.Node; import org.w3c.dom.NodeList; public class XMLParser { public static void main(String[] args) { try { // 创建一个DocumentBuilderFactory对象 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); // 使用DocumentBuilderFactory对象创建一个DocumentBuilder对象 DocumentBuilder builder = factory.newDocumentBuilder(); // 使用DocumentBuilder对象的parse()方法解析XML文件,返回一个表示整个文档的Document对象 Document document = builder.parse("data.xml"); // 获取根元素 Element root = document.getDocumentElement(); // 获取所有的子元素 NodeList nodeList = root.getChildNodes(); // 遍历所有的子元素 for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); // 判断子元素是否为元素节点 if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; // 获取元素的标签名 String tagName = element.getTagName(); // 获取元素的文本内容 String textContent = element.getTextContent(); // 输出标签名和文本内容 System.out.println("标签名: " + tagName); System.out.println("文本内容: " + textContent); } } } catch (Exception e) { e.printStackTrace(); } } } ``` 以上代码使用Java的内置类库 javax.xml.parsers 和 org.w3c.dom 实现了解析XML文件的功能。我们首先创建了一个 DocumentBuilderFactory 对象,然后使用该对象创建了一个 DocumentBuilder 对象。接下来,调用 DocumentBuilder 对象的 parse() 方法解析指定的 XML 文件,得到一个 Document 对象。通过 Document 对象,我们可以获取根元素和其子元素,并遍历这些元素,获取标签名和文本内容。 需要注意的是,以上代码中的 "data.xml" 是需要解析XML 文件的路径,请根据实际情况进行修改。另外,解析XML文件可能涉及更复杂的操作,如获取元素的属性值等。以上代码仅仅是一个基本的示例,供参考。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值