14-XML与JSON(核心类库)

感谢你的路过,希望学生的笔记能给你一点微不足道的参考(2/100)
Java基础思维导图,完整Java体系的链接
在这里插入图片描述
在这里插入图片描述

一,XML介绍

1.1简介:

   可扩展标记语言(eXtensible Markup Language)。 特性: 1. xml具有平台无关性, 是一门独立的标记语言. 2. xml具有自我描述性

1.2为什么学习XML?

在这里插入图片描述
   1. 网络数据传输
   2. 数据存储
   3. 配置文件

1.3XML文件

   XML文件是保存XML数据的一种方式 XML数据也可以以其他的方式存在(如在内存中构建XML数据)。 不要将XML语言狭隘的理解成XML文件

二,XML语法格式

2.1XML文档声明

   <?xml version=“1.0” encoding=“UTF-8”>

2.2标记 ( 元素 / 标签 / 节点) XML文档,由一个个的标记组成.

   语法:
      开始标记(开放标记): <标记名称>
      结束标记(闭合标记): </标记名称>
   标记名称: 自定义名称,必须遵循以下命名规则:
      1.名称可以含字母、数字以及其他的字符
      2.名称不能以数字或者标点符号开始
      3.名称不能以字符 “xml”(或者 XML、Xml)开始
      4.名称不能包含空格,不能包含冒号(:)
      5.名称区分大小写
   标记内容: 开始标记与结束标记之间 ,是标记的内容.
      例如 ,我们通过标记, 描述一个人名: 李伟杰

2.3一个XML文档中, 必须有且且仅允许有一个根标记.

2.4标记可以嵌套, 但是不允许交叉.

2.5标记的层级称呼 (子标记, 父标记 , 兄弟标记, 后代标记 ,祖先标记)

   例如:

<persons>
	<person>
		<name>李四</name>
		<length>180cm</length>
	</person>
	<person>
		<name>李四</name>
		<length>200cm</length>
	</person>
</persons>

      name是person的子标记.也是person的后代标记
      name是persons的后代标记. name是length的兄弟标记.
      person是name的父标记. persons是name的祖先标记.

2.6标记名称 允许重复

2.7标记除了开始和结束 , 还有属性.

    标记中的属性, 在标记开始时 描述, 由属性名和属性值 组成.
    格式: 在开始标记中, 描述属性. 可以包含0-n个属性, 每一个属性是一个键值对! 属性名不允许重复 , 键与值之间使用等号连接, 多个属性之间使用空格分割. 属性值 必须被引号引住.
    例子:
在这里插入图片描述

2.8注释 注释不能写在文档文档声明前 注释不能嵌套注释

   格式:

注释开始: <!--
注释结束:-->

代码:

package com.wyh;

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

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.List;

/**
 * xml解析本地文件。
 * 读取文件里的xml格式内容,并输出
 */
public class Demo1 {
   
    public static void main(String[] args) throws IOException, DocumentException {
   
        //1.    获取输入流
        FileInputStream fis = new FileInputStream("D:\\eclipse-workspace\\C_XX_HeXinLeiKu\\g_XX_ XMLYuJSON\\file\\Demo1.xml");
        //2.    创建XML读取对象
        SAXReader sr = new SAXReader();
        //3.    读取并得到文档对象
        Document doc = sr.read(fis);
        //4.    通过文档获取根元素
        Element root = doc.getRootElement();
        //5.    开始解析元素
        System.out.println(root.getName());

        //操作一波
        //Element book = root.element("book");
        //Element name = book.element("name");
        //System.out.println(name.getText());
        List<Element> es = root.elements();
        for(int i=0;i<es.size();i++){
   
            Element book = es.get(i);
            System.out.println(book.attributeValue("id"));
            System.out.println(book.elementText("name"));
            System.out.println(book.elementText("info"));
            System.out.println("-----------------------------");
        }

        fis.close();
    }
}
package com.wyh;

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

import java.io.IOException;
import java.io.InputStream;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
/**
 * xml解析网络文件。
 * 读取文件里的xml格式内容,并输出
 */
public class Demo2 {
   
    public static void main(String[] args) throws IOException, DocumentException {
   
        String phone = "13766540206";
        //1.    获取到XML资源的输入流
        URL url = new URL("http://apis.juhe.cn/mobile/get?phone="+phone+"&dtype=xml&key=9f3923e8f87f1ea50ed4ec8c39cc9253");
        URLConnection conn = url.openConnection(); // 打开连接
        InputStream is = conn.getInputStream();
        //2.    创建一个XML读取对象
        SAXReader sr = new SAXReader();
        //3.    通过读取对象 读取XML数据,并返回文档对象
        Document doc = sr.read(is)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值