(一)XML基础概念

1、XML概念

定义:XML为可扩展标记性语言。
作用:
  1、保存具有自我描述性的数据。
  2、为项目或模块配置文件。
  3、作为网络传输数据格式。
  现阶段XML使用的地方较多,轻量级数据传输会用到JSON,XML是为了替代HTML被提出来的,因为语法比较严格。
  以下例子为XML存储书籍,首先新建标签books(复数),内部采用book标签进行每一本书的存储。

2、XML语法

2.1文档声明

<?xml version="1.0" encoding="utf-8" ?>
<!-- xml声明 version是版本的意思   encoding是编码  -->

2.2元素(标签)

  XML元素是指从(且包括)开始标签到(包括)结束标签的部分,元素可以包括其它元素、文本混合物。元素也可以拥有属性。

<books> <!-- 这是xml注释 -->
    <book id="SN123123413241"> <!-- book标签描述一本图书   id属性描述 的是图书 的编号  -->
        <name>人工智能</name> <!-- name标签描述 的是图书 的信息 -->
        <author>斯蒂芬孙</author>		<!-- author单词是作者的意思 ,描述图书作者 -->
        <price>9.9</price>		<!-- price单词是价格,描述的是图书 的价格 -->
    </book>
    <book id="SN12341235123">	<!-- book标签描述一本图书   id属性描述 的是图书 的编号  -->
        <name>Java编程</name>	<!-- name标签描述 的是图书 的信息 -->
        <author>新海诚</author>	<!-- author单词是作者的意思 ,描述图书作者 -->
        <price>99</price>	<!-- price单词是价格,描述的是图书 的价格 -->
    </book>
</books>

2.3XML命名规则

2.3.1命名要求

  名称可以含有字母、数字以及其它字符
例如:

<book id="SN15151545454">
	<author>作者</author>
	<name>安徒生的童话</name>
	<price>939</price>
</book>

  名称不能以数字或者标点符号开始或包含空格。
错误示范:
以数字或者标点符号开头:

<books> <!-- 这是xml注释 -->
    <121book id="SN123123413241"> <!-- book标签描述一本图书   id属性描述 的是图书 的编号  -->
        <name>人工智能</name> <!-- name标签描述 的是图书 的信息 -->
        <author>斯蒂芬孙</author>		<!-- author单词是作者的意思 ,描述图书作者 -->
        <price>9.9</price>		<!-- price单词是价格,描述的是图书 的价格 -->
    </book>
    <book id="SN12341235123">	<!-- book标签描述一本图书   id属性描述 的是图书 的编号  -->
        <name>Java编程</name>	<!-- name标签描述 的是图书 的信息 -->
        <author>新海诚</author>	<!-- author单词是作者的意思 ,描述图书作者 -->
        <price>99</price>	<!-- price单词是价格,描述的是图书 的价格 -->
    </book>
</books>

不能空格开头或有空格:

<bo oks> <!-- 这是xml注释 -->
    <121book id="SN123123413241"> <!-- book标签描述一本图书   id属性描述 的是图书 的编号  -->
        <name>人工智能</name> <!-- name标签描述 的是图书 的信息 -->
        <author>斯蒂芬孙</author>		<!-- author单词是作者的意思 ,描述图书作者 -->
        <price>9.9</price>		<!-- price单词是价格,描述的是图书 的价格 -->
    </book>
    <book id="SN12341235123">	<!-- book标签描述一本图书   id属性描述 的是图书 的编号  -->
        <name>Java编程</name>	<!-- name标签描述 的是图书 的信息 -->
        <author>新海诚</author>	<!-- author单词是作者的意思 ,描述图书作者 -->
        <price>99</price>	<!-- price单词是价格,描述的是图书 的价格 -->
    </book>
</bo oks>

  对大小写很敏感,格式要求比较规范。
错误示范:

<books>
	·········<错误写法>
</BOOKS>

2.3.2格式要求

  所有XML元素必须含有关闭标签。

<books>

  标签必须正确嵌套。

<books>
	<book>
	·········<错误写法>
</BOOKS></book>

  必须具有根元素。
  根元素是顶级元素,根元素是没有父标签的顶级元素。

	<books>
		·········<错误写法>
	</books>
</mybooks>

2.4文本区域(CDATA区)

  遇到不需要XML解析的纯文本内容可以使用CDATA格式。

<![CDATA[这里属于原始文字]]>

2.4.1单标签和双标签

  双标签在内部添加元素:

<book id="SN15151545454">
	<author>作者</author>
	<name>安徒生的童话</name>
	<price>939</price>
</book>

  单标签整合为一条XML标签:

<book id="SN15151545454" name = "安徒生童话"/>

2.4.2特殊符号

  比如要在Markdown或者XML中写小于号<和大于号>。使用&lt;表示<。使用&gt;表示>,注意要切换到英文输入法。

<test>
	<spe>&lt;书籍&gt;</spe>
</test>

  在实际中显示为大于号和小于号。

3、XML属性

  属性必须用引号表示,否则会报错。属性为元素中的内容,元素是一条标签。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答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文件可能涉及更复杂的操作,如获取元素的属性值等。以上代码仅仅是一个基本的示例,供参考。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

面条有点辣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值