XML 指可扩展标记语言(EXtensible Markup Language)
XML是用来存储数据, 传输数据的,不是用来显示数据的。HTML是用来显示数据的。
XML 标签没有被预定义。是需要自行定义标签。
XML 是 W3C 的推荐标准
W3C在1988年2月发布1.0版本,2004年2月又发布1.1版本,但因为1.1版本不能向下兼容1.0版本,所以1.1没有人用。同时,在2004年2月W3C又发布了1.0版本的第三版。到目前为止我们使用的还是1.0
(服务器和前端交互数据用xml,现在一般用json)
一个标准XML文件一般由以下几部分组成:文档声明、元素、属性、注释、转义字符、字符区。
<?xml version="1.0" encoding="utf-8" ?>
文档声明可以不写
文档声明必须为<?xml开头,以?>结束
文档声明必须从文档的1行1列位置开始(左上角顶格)
文档声明中常见的两个属性:
元素是XML中最重要的组成部分,元素也叫标签
标签分为开始标签和结束标签,开始标签<名字> 结束标签</名字>
开始标签和结束标签中间写的是标签内容,标签的内容可以是文本,也可以是其他标签
如果标签没有任何内容,那么可以定义空标签(比如:<名字/>)
标签可以嵌套,但是不能乱嵌套
一个XML文件只有一个根标签
命名规则:
不要使用XML xML xml 写样的单词
不能使用空格,冒号
命名区分大小写
数字不能开头
位置: 属性是元素的一部分,它必须出现在元素的开始标签中,不能写在结束标签中
格式: 属性的定义格式:属性名=“属性值”,其中属性值必须使用单引或双引号括起来
一个元素可以有0~N个属性,但一个元素中不能出现同名属性
属性名不能使用空格 , 不要使用冒号等特殊字符,且必须以字母开头
<?xml version="1.0" encoding="UTF-8" ?>
<persons>
<person>
<name>唐三</name>
<age>16</age>
</person>
<!--空标签-->
<person></person>
<person/>
<!--属性-->
<person name='小舞' age="15"></person>
</persons>
<!--注释内容-->
<!--
开始,-->
结束。ctrl + /
单行 ctrl+shift+/
多行-在xml中,一些符号被文档结构使用,想要在元素体或属性值使用这些符号,会造成冲突。
-为了避免这些冲突,定义了表示这些符号的字符,以便在元素体或属性值中使用。
这些字符称为转义字符,也叫实体字符。XML中的转义字符与HTML中的一样。
-1. 小于号(<):–><
-2. 大于号(>):–>>
-3. 与符号(&):–>&
-4. 单引号(‘):–>'
-5. 双引号(“):–>"
-注意:严格讲,在XML中仅有字符 "<“和”&"是非法的。省略号、单双引号和大于号是合法的,但将其替换为实体引用是个好习惯。
转义字符应用示例:
<price> 苹果的价格: price > 5 && price < 10</price>
<![CDATA[
文本数据
]]>
<!--快捷键:CD-->
<!-- 案例 -->
<price>
<![CDATA[
苹果的价格: price > 5 && price < 10
]]>
</price>
在XML技术里,可以编写一个文档来约束一个XML文档的书写规范,这称之为XML约束。
约束文档定义了在XML中允许出现的元素(标签)名称、属性及元素(标签)出现的顺序等等。
两种约束:DTD约束(文件后缀为dtd),Schema约束(文件后缀为xsd)
注意: 约束不是我们要写的东西,我们的工作是根据约束去写XML
DTD约束文档
<?xml version="1.0" encoding="UTF-8" ?>
<!--书架是书的父标签,书标签可以有1个或者多个(大于等于1)-->
<!ELEMENT 书架 (书+)>
<!--书是书名、作者、售价的父标签,他们出现的顺序必须是: 书名 作者 售价-->
<!ELEMENT 书 (书名,作者,售价)>
<!--书名标签的标签体是文本-->
<!ELEMENT 书名 (#PCDATA)>
<!--作者标签的标签体是文本-->
<!ELEMENT 作者 (#PCDATA)>
<!--售价标签的标签体是文本-->
<!ELEMENT 售价 (#PCDATA)>
<!--
书标签中有id,编号,出版社,type这4个属性
书标签中id属性的类型是ID类型(值唯一,不能以数字开头),而且id属性必须出现
书标签中编号属性的类型是CDATA(文本\字符串),可以出现也可以不出现
书标签中出版社属性的类型是枚举类型,默认值是清华
书标签中type属性类型是CDATA(文本\字符串),固定值是IT
-->
<!ATTLIST 书
id ID #REQUIRED
编号 CDATA #IMPLIED
出版社 (清华|北大|浙大) "清华"
type CDATA #FIXED "IT"
>
XML
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE 书架 SYSTEM "bookdtd.dtd">
<书架>
<书 id="a1" 编号="001" 出版社="清华">
<书名>斗罗大陆</书名>
<作者>唐家三少</作者>
<售价>99.8</售价>
</书>
<书 id="a2" type="IT">
<书名>斗破苍穹</书名>
<作者>天蚕土豆</作者>
<售价>99.8</售价>
</书>
</书架>
内部DTD,在XML文档内部嵌入DTD,只对当前XML有效。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE 根元素 [元素声明]>
<!DOCTYPE 书架 [
<!ELEMENT 书架 (书+)>
<!ELEMENT 书 (书名,作者,售价)
<!ELEMENT 书名 (#PCDATA)>
<!ELEMENT 作者 (#PCDATA)>
<!ELEMENT 售价 (#PCDATA)>
]>
外部DTD—本地DTD,DTD文档在本地系统上,企业内部自己项目使用。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE 根元素 SYSTEM "文件名">
<!DOCTYPE 书架 SYSTEM "bookdtd.dtd">
外部DTD—公共DTD,DTD文档在网络上,一般都有框架提供 , 也是我们使用最多的.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE 根元素 PUBLIC "DTD名称" "DTD文档的URL">
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd">
约束元素的嵌套层级
语法
<!ELEMENT 父标签 (子标签…)>
例如:
<!ELEMENT books (book+)> <!--约束根元素是"books","books"子元素为"book",“+”为数量词-->
<!ELEMENT book (name,author,price)><!--约束"book"子元素依次为“name”、“author”、“price”,-->
约束元素体里面的数据
语法
<!ELEMENT 标签名字 标签类型>
例如 <!ELEMENT name (#PCDATA)>
标签类型: EMPTY(即空元素,例如<hr/>) ,ANY(任意类型) ,(#PCDATA) 字符串数据
代码
<!ELEMENT name ANY>
<!ELEMENT author EMPTY>
<!ELEMENT price (#PCDATA)>
数量词(掌握)
数量词符号 | 含义 |
---|---|
* | 表示元素可以出现0到多个 |
+ | 表示元素可以出现至少1个 |
? | 表示元素可以是0或1个 |
, | 表示元素需要按照顺序显示 |
| | 表示元素需要选择其中的某一个 |
语法
<!ATTLIST 标签名称
属性名称1 属性类型1 属性说明1
属性名称2 属性类型2 属性说明2
…
>
例如
<!ATTLIST book
bid ID #REQUIRED
>
属性类型
属性说明:
属性说明
代码
<!ATTLIST 书 <!--设置"书"元素的的属性列表-->
id ID #REQUIRED <!--"id"属性值为必须有-->
编号 CDATA #IMPLIED <!--"编号"属性可有可无-->
出版社 (清华|北大|浙大) "浙大" <!--"出版社"属性值是枚举值,默认为“浙大”-->
type CDATA #FIXED "IT" <!--"type"属性为文本字符串并且固定值为"IT"-->
>
<?xml version = "1.0" encoding="GB2312" standalone="yes"?>
<!DOCTYPE 购物篮 [
<!ELEMENT 购物篮 (肉+)>
<!ELEMENT 肉 EMPTY>
<!ATTLIST 肉 品种 ( 鸡肉 | 牛肉 | 猪肉 | 鱼肉 ) "鸡肉">
]>
<购物篮>
<肉 品种="牛肉"></肉>
<肉/>
</购物篮>
schema和DTD一样, 也是一种XML文件的约束.
Schema 语言也可作为 XSD(XML Schema Definition)。
Schema约束的文件的后缀名.xsd
Schema 功能更强大,数据类型约束更完善。
Schema约束文档:
<?xml version="1.0" encoding="UTF-8" ?>
<!--此内容复制到xml文档里,引入xsd约束
<书架 xmlns="http://www.geekly.top"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.geekly.top bookSchema.xsd" >
-->
<xs:schema
xmlns:xs="http://www.w3.org/2001/XMLSchema"
targetNamespace="http://www.geekly.top"
elementFormDefault="qualified">
<!--element:元素-->
<!--根标签名为书架-->
<xs:element name='书架'>
<!--complexType:复杂类型-->
<!--书架标签是一个复杂类型标签,书架标签下面有子标签-->
<xs:complexType>
<!--sequence: 子标签需要按照顺序出现-->
<!--maxOccurs: 最多出现多少次-->
<!--minOccurs: 最少出现多少次-->
<!--unbounded: 没有界限(无限次)-->
<!--书架子标签至少出现1次,最多出现2次-->
<xs:sequence minOccurs="1" maxOccurs='2'>
<!--书架子标签名为书-->
<xs:element name='书'>
<!--书标签是一个复杂类型的标签,书标签下面有子标签-->
<xs:complexType>
<!--书标签的子标签需要按照顺序出现: 书名,作者,售价-->
<xs:sequence>
<!--书名标签的类型是string-->
<xs:element name='书名' type='xs:string'/>
<!--作者标签的类型是string-->
<xs:element name='作者' type='xs:string'/>
<!--售价标签的类型是double-->
<xs:element name='售价' type='xs:double'/>
</xs:sequence>
<!--attribute: 属性,optional:可有可无,required:必须有-->
<!--书标签下有bid属性,类型为int,约束为: 可有可无-->
<xs:attribute name="bid" type="xs:int" use="optional"/>
</xs:complexType>
</xs:element>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
根据上面的Schema约束编写XML
<?xml version="1.0" encoding="UTF-8" ?>
<书架 xmlns="http://www.geekly.top"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.geekkly.top bookSchema.xsd" >
<书 bid="1">
<书名>斗罗大陆</书名>
<作者>唐家三少</作者>
<售价>99.8</售价>
</书>
<书 bid="2">
<书名>斗破苍穹</书名>
<作者>天蚕土豆</作者>
<售价>99.8</售价>
</书>
</书架>
开发中比较常见的解析方式有三种,如下:
DOM:要求解析器把整个XML文档装载到内存,并解析成一个Document对象
a)优点:元素与元素之间保留结构关系,故可以进行增删改查操作。
b)缺点:XML文档过大,可能出现内存溢出
SAX:是一种速度更快,更有效的方法。她逐行扫描文档,一边扫描一边解析。并以事件驱动的方式进行具体解析,每执行一行,都触发对应的事件。(了解)
a)优点:不会出现内存问题,可以处理大文件
b)缺点:只能读,不能回写。
PULL:Android内置的XML解析方式,类似SAX。(了解)
解析器,就是根据不同的解析方式提供具体实现。有的解析器操作过于繁琐,为了方便开发人员,有提供易于操作的解析开发包
解析原理
XML DOM 和 HTML DOM一样,XML DOM 将整个XML文档加载到内存,生成一个DOM树,并获得一个Document对象,通过Document对象就可以对DOM进行操作。
结构模型
DOM中的核心概念就是节点,在XML文档中的元素、属性、文本,在DOM中都是节点!所有的节点都封装到了Document对象中。
1.创建解析器对象: SAXReader sr = new SAXReader();
2.读取xml文件进行解析,生成Document对象---使用SAXReader方法
Document read(String fileName);
3.使用Document对象获取根元素
Element getRootElement();
4.使用元素获取子元素--->使用Element方法
public List elements() : 获取当前元素的所有子元素
public String getName() : 获取元素的元素名
public String getText() : 获取当前元素的文本值
public String attributeValue(String name) : 获取当前元素下某个属性的值,传入属性名
public Element element(String name) : 根据元素名获取指定子元素(如果有多个就获取到第一个)
public String elementText(String name) : 获取指定子元素的文本值,参数是子元素名称
xml
<?xml version="1.0" encoding="utf-8" ?>
<books>
<book id="0001">
<name>JavaWeb开发教程</name>
<author>张孝祥</author>
<sale>100.00元</sale>
</book>
<book id="0002">
<name>三国演义</name>
<author>罗贯中</author>
<sale>100.00元</sale>
</book>
</books>
解析
public class Test {
public static void main(String[] args) throws Exception {
/*
使用步骤:
1.创建解析器对象: SAXReader sr = new SAXReader();
2.读取xml文件进行解析,生成Document对象---使用SAXReader方法
Document read(String fileName);
3.使用Document对象获取根元素
Element getRootElement();
4.使用元素获取子元素--->使用Element方法
public List elements() : 获取当前元素的所有子元素
public String getName() : 获取元素的元素名
public String getText() : 获取当前元素的文本值
public String attributeValue(String name) : 获取当前元素下某个属性的值,传入属性名
public Element element(String name) : 根据元素名获取指定子元素(如果有多个就获取到第一个)
public String elementText(String name) : 获取指定子元素的文本值,参数是子元素名称
*/
// 1.创建解析器对象
SAXReader sr = new SAXReader();
// 2.读取xml文件进行解析,生成Document对象
Document document = sr.read("day1\\books.xml");
// 3.使用Document对象获取根标签
Element rootE = document.getRootElement();
System.out.println("根标签的名:"+rootE.getName());// 根标签的名:books
// 4.获取根标签下的所有子标签
List<Element> list1 = rootE.elements();
// 5.循环遍历根标签下的所有子标签
for (Element e1 : list1) {// e1: book,book
System.out.println("根标签的子标签名:"+e1.getName());
System.out.println("子标签的id属性值:" + e1.attributeValue("id"));
// 6.获取book标签下的所有子标签
List<Element> list2 = e1.elements();
// 7.循环遍历book标签下的所有子标签
for (Element e2 : list2) {// e2: name,author,sale
System.out.println("book标签下的子标签名:"+e2.getName());
System.out.println("book标签下的子标签的文本内容:"+e2.getText());
}
}
// public Element element(String name) : 根据元素名获取指定子元素(如果有多个就获取到第一个)
Element bookE = rootE.element("book");
System.out.println("根标签下的第一个book子标签:"+bookE.getName()+",id属性:"+bookE.attributeValue("id"));
// public String elementText(String name) : 获取指定子元素的文本值,参数是子元素名称
String text = bookE.elementText("author");
System.out.println("第一个book标签下的author子标签的文本:"+text);// 张孝祥
}
}
XPath 使用路径表达式来选取HTML\XML 文档中的元素节点或属性节点。节点是通过沿着路径 (path) 来选取的。XPath在解析HTML\XML文档方面提供了独树一帜的路径思想。
说白了就是用来表示xml文件中标签或者属性的路径
步骤1:导入jar包(dom4j和jaxen-1.1-beta-6.jar)
步骤2:通过dom4j的SaxReader解析器对象,读xml文件,生成Document对象
步骤3: 利用Xpath提供的api,对XML文档中的标签或者属性进行解析操作。
document常用的api
XPath表达式,就是用于选取HTML文档中节点的表达式字符串。
获取XML文档节点元素一共有如下4种XPath语法方式:
以/开头的路径叫做是绝对路径,绝对路径要从根元素开始写
public class Test1_绝对路径 {
public static void main(String[] args) throws Exception {
// 1.创建解析器对象
SAXReader sr = new SAXReader();
// 2.读xml文件,生成Document对象
Document document = sr.read("day1\\tianqi.xml");
// 需求:查询深圳的最低温度
Element e1 = (Element) document.selectSingleNode("/天气预报/深圳/温度/最低温度");
System.out.println("e1标签名:" + e1.getName() + ",文本:" + e1.getText());
Node n1 = document.selectSingleNode("/天气预报/深圳/温度/最低温度");
System.out.println("e1标签名:" + n1.getName() + ",文本:" + n1.getText());
element是node的子标签
}
}
相对路径就是相对当前节点元素位置继续查找节点,不以/开头, …/ 表示上一个元素, **./**表示当前元素
public class Test2_相对路径 {
public static void main(String[] args) throws Exception {
// 1.创建解析器对象
SAXReader sr = new SAXReader();
// 2.读xml文件,生成Document对象
Document document = sr.read("day1\\tianqi.xml");
// 3.获取深圳的最低温度
Element e1 = (Element) document.selectSingleNode("/天气预报/深圳/温度/最低温度");
System.out.println("e1标签名:" + e1.getName() + ",文本:" + e1.getText());
// 需求: 根据e1获取广州最低温度
Element e2 = (Element) e1.selectSingleNode("../../../广州/温度/最低温度");
System.out.println("e2标签名:" + e2.getName() + ",文本:" + e2.getText());
}
}
##### 2.3.3.3 全文搜索路径表达式
- 代表不论中间有多少层,直接获取所有子元素中满足条件的元素,需要使用//
```java
public class Test3_全文搜索路径 {
public static void main(String[] args) throws Exception {
// 1.创建解析器对象
SAXReader sr = new SAXReader();
// 2.读xml文件,生成Document对象
Document document = sr.read("day1\\tianqi.xml");
// 需求:查询所有的最低温度
List<Element> list = document.selectNodes("//最低温度");
for (Element e : list) {
System.out.println(e.getName()+","+e.getText());
}
}
}
介绍
谓语,又称为条件筛选方式,就是根据条件过滤判断进行选取节点
格式:
String xpath1="//元素[@attr1=value]";//获取元素属性attr1=value的元素
String xpath2="//元素[@attr1>value]/@attr1"//获取元素属性attr1>value的所有attr1的值
String xpath3="//元素[@attr1=value]/text()";//获取符合条件元素体的自有文本数据
String xpath4="//元素[@attr1=value]/html()";//获取符合条件元素体的自有html代码数据。
String xpath3="//元素[@attr1=value]/allText()";//获取符合条件元素体的所有文本数据(包含子元素里面的文本)
public class Test4_条件筛选路径 {
public static void main(String[] args) throws Exception {
// 1.创建解析器对象
SAXReader sr = new SAXReader();
// 2.读xml文件,生成Document对象
Document document = sr.read("day1\\tianqi.xml");
// 需求:查询所有的等级属性为C的最高温度
List<Element> list = document.selectNodes("//最高温度[@level='C']");
for (Element e : list) {
System.out.println(e.getName()+","+e.getText()+","+e.attributeValue("level"));
}
}
}
概述: 正则表达式其实就是一个匹配规则,用来替换之前复杂的if结构判断
在Java中,我们经常需要验证一些字符串,是否符合规则, 例如:校验qq号码是否正确,手机号码是否正确,邮箱是否正确等等。那么如果使用if就会很麻烦, 而正则表达式就是用来验证各种字符串的规则。它内部描述了一些规则,我们可以验证用户输入的字符串是否匹配这个规则。
先看一个不使用正则表达式验证的例子:下面的程序让用户输入一个QQ号码,我们要验证:
使用if判断方式验证:
public class Test {
public static void main(String[] args) {
System.out.println(checkQQ1("12345678"));// true
System.out.println(checkQQ1("1234"));// false
System.out.println(checkQQ1("1234a5678"));// false
System.out.println(checkQQ1("02345678"));// false
}
public static boolean checkQQ1(String qq) {
//- QQ号码必须是5--15位长度-->只要长度不是[5,15],就直接返回false结束方法
if (qq.length() < 5 || qq.length() > 15) {
return false;
}
//- 而且必须全部是数字-->只要有任何一位不是数字,就直接返回false结束方法
for (int i = 0; i < qq.length(); i++) {
char c = qq.charAt(i);
if (c < '0' || c > '9'){
return false;
}
}
//- 而且首位不能为0--->只要首位为0字符,就直接返回false结束方法
if (qq.charAt(0) == '0'){
return false;
}
return true;
}
}
使用正则表达式验证:
public boolean matches(String regex); 判断此字符串是否匹配给定的正则表达式
public class Test {
public static void main(String[] args) {
System.out.println(checkQQ2("12345678"));// true
System.out.println(checkQQ2("1234"));// false
System.out.println(checkQQ2("1234a5678"));// false
System.out.println(checkQQ2("02345678"));// false
}
public static boolean checkQQ2(String qq){
return qq.matches("[1-9]\\d{4,14}");
}
}
语法示例:[] 表示匹配单个字符 ^ 取反 - 范围
[abc]:代表a或者b,或者c字符中的一个。
[^abc]:代表除a,b,c以外的任何字符。
[a-z]:代表a-z的所有小写字符中的一个。 左右包含
[A-Z]:代表A-Z的所有大写字符中的一个。
[0-9]:代表0-9之间的某一个数字字符。
[a-zA-Z0-9]:代表a-z或者A-Z或者0-9之间的任意一个字符。
[a-dm-p]:a 到 d 或 m 到 p之间的任意一个字符。
代码示例:
public class Test1_字符类 {
public static void main(String[] args) {
/*
正则表达式-字符类
- 语法示例:[] 表示匹配单个字符 ^ 取反 - 范围
1. [abc]:代表a或者b,或者c字符中的一个。
2. [^abc]:代表除a,b,c以外的任何字符。
3. [a-z]:代表a-z的所有小写字符中的一个。 左右包含
4. [A-Z]:代表A-Z的所有大写字符中的一个。
5. [0-9]:代表0-9之间的某一个数字字符。
6. [a-zA-Z0-9]:代表a-z或者A-Z或者0-9之间的任意一个字符。
7. [a-dm-p]:a 到 d 或 m 到 p之间的任意一个字符。
*/
// 需求:
// 1.验证字符串是否以h开头,以d结尾,中间是a,e,i,o,u中某个字符
System.out.println("had".matches("h[aeiou]d"));// true
System.out.println("hbd".matches("h[aeiou]d"));// false
System.out.println("h1d".matches("h[aeiou]d"));// false
System.out.println("haa".matches("h[aeiou]d"));// false
System.out.println("haod".matches("h[aeiou]d"));// false
System.out.println("---------");
// 2.验证字符串是否以h开头,以d结尾,中间不是a,e,i,o,u中的某个字符
System.out.println("had".matches("h[^aeiou]d"));// false
System.out.println("hbd".matches("h[^aeiou]d"));// true
System.out.println("h1d".matches("h[^aeiou]d"));// true
System.out.println("haa".matches("h[^aeiou]d"));// false
System.out.println("haod".matches("h[^aeiou]d"));// false
System.out.println("---------");
// 3.验证字符串是否a-z的任何一个小写字符开头,后跟ad
System.out.println("had".matches("[a-z]ad"));// true
System.out.println("hbd".matches("[a-z]ad"));// false
System.out.println("h1d".matches("[a-z]ad"));// false
System.out.println("haa".matches("[a-z]ad"));// false
System.out.println("haod".matches("[a-z]ad"));// false
System.out.println("---------");
// 4.验证字符串是否以a-d或者m-p之间某个字符开头,后跟ad
System.out.println("aad".matches("[a-dm-p]ad"));// true
System.out.println("had".matches("[a-dm-p]ad"));// false
System.out.println("hbd".matches("[a-dm-p]ad"));// false
System.out.println("h1d".matches("[a-dm-p]ad"));// false
System.out.println("haa".matches("[a-dm-p]ad"));// false
System.out.println("haod".matches("[a-dm-p]ad"));// false
System.out.println("---------");
}
}
语法示例:
代码示例:
public class Test2_逻辑运算符 {
public static void main(String[] args) {
/*
1. &&:并且
2. | :或者
*/
// 需求:
//1.要求字符串是小写辅音字符开头,后跟ad 除了a,e,i,o,u之外,其他的都是辅音字母
System.out.println("bad".matches("[a-z&&[^aeiou]]ad"));// true
System.out.println("aad".matches("[a-z&&[^aeiou]]ad"));// false
System.out.println("4ad".matches("[a-z&&[^aeiou]]ad"));// false
System.out.println("----------");
//2.要求字符串是aeiou中的某个字符开头,后跟ad
System.out.println("aad".matches("[a|e|i|o|u]ad"));// true
System.out.println("bad".matches("[a|e|i|o|u]ad"));// false
System.out.println("2ad".matches("[a|e|i|o|u]ad"));// false
}
}
语法示例:
\\.
代码示例:
public class Test3_预定义字符 {
public static void main(String[] args) {
/*
正则表达式-预定义字符
- 语法示例:
1. "." : 匹配任何字符。如果要表示一个字符点,那么就得使用\.
2. "\d":任何数字[0-9]的简写;
3. "\D":任何非数字[^0-9]的简写;
4. "\s": 空白字符:[ \t\n\x0B\f\r] 的简写
5. "\S": 非空白字符:[^\s] 的简写
6. "\w":单词字符:[a-zA-Z_0-9]的简写
7. "\W":非单词字符:[^\w]
*/
// 需求:
// 1.验证字符串是否是3位数字
System.out.println("123".matches("[1-9]\\d\\d"));// true
System.out.println("023".matches("[1-9]\\d\\d"));// false
System.out.println("a23".matches("[1-9]\\d\\d"));// false
System.out.println("1234".matches("[1-9]\\d\\d"));// false
System.out.println("--------");
// 2.验证手机号:1开头,第二位:3/5/8,剩下9位都是0-9的数字
System.out.println("13868686668".matches("1[358]\\d\\d\\d\\d\\d\\d\\d\\d\\d"));// true
System.out.println("17868686668".matches("1[358]\\d\\d\\d\\d\\d\\d\\d\\d\\d"));// false
System.out.println("27868686668".matches("1[358]\\d\\d\\d\\d\\d\\d\\d\\d\\d"));// false
System.out.println("1586868666".matches("1[358]\\d\\d\\d\\d\\d\\d\\d\\d\\d"));// false
System.out.println("--------");
// 3.验证字符串是否以h开头,以d结尾,中间是任何字符
System.out.println("had".matches("h.d"));// true
System.out.println("h%d".matches("h.d"));// true
System.out.println("h.d".matches("h.d"));// true
System.out.println("h d".matches("h.d"));// true
System.out.println("hd".matches("h.d"));// false
System.out.println("--------");
// 4.验证str是否是:h.d
System.out.println("had".matches("h\\.d"));// false
System.out.println("h%d".matches("h\\.d"));// false
System.out.println("h.d".matches("h\\.d"));// true
System.out.println("h d".matches("h\\.d"));// false
System.out.println("hd".matches("h\\.d"));// false
System.out.println("--------");
}
}
语法示例:
代码示例:
public class Test4_数量词 {
public static void main(String[] args) {
/*
正则表达式-数量词
- 语法示例:
1. X? : 0次或1次
2. X* : 0次到多次
3. X+ : 1次或多次
4. X{n} : 恰好n次
5. X{n,} : 至少n次
6. X{n,m}: n到m次(n和m都是包含的)
*/
// 需求:
// 1.验证字符串是否是3位数字
System.out.println("123".matches("[1-9]\\d{2}"));// true
System.out.println("023".matches("[1-9]\\d{2}"));// false
System.out.println("a23".matches("[1-9]\\d{2}"));// false
System.out.println("1234".matches("[1-9]\\d{2}"));// false
System.out.println("--------");
// 2.验证str是否是多位数字
System.out.println("123".matches("[1-9]\\d*"));// true
System.out.println("023".matches("[1-9]\\d*"));// false
System.out.println("a23".matches("[1-9]\\d*"));// false
System.out.println("1234".matches("[1-9]\\d*"));// true
System.out.println("--------");
// 3.验证手机号:1开头,第二位:3/5/8,剩下9位都是0-9的数字
System.out.println("13868686668".matches("1[358]\\d{9}"));// true
System.out.println("17868686668".matches("1[358]\\d{9}"));// false
System.out.println("27868686668".matches("1[358]\\d{9}"));// false
System.out.println("1586868666".matches("1[358]\\d{9}"));// false
System.out.println("--------");
// 4.验证qq号码:1).5--15位;2).全部是数字;3).第一位不是0
System.out.println("12345678".matches("[1-9]\\d{4,14}"));// true
System.out.println("1234".matches("[1-9]\\d{4,14}"));// false
System.out.println("1234a5678".matches("[1-9]\\d{4,14}"));// false
System.out.println("02345678".matches("[1-9]\\d{4,14}"));// false
}
}
public class Test5_分组括号 {
public static void main(String[] args) {
/*
分组括号: ()
使用:格式相同的就分为一组
*/
String str = "DG8FV-B9TKY-FRT9J-99899-XPQ4G";
System.out.println(str.matches("([A-Z0-9]{5}-){4}[A-Z0-9]{5}"));// true
// 叠词aabb格式: 高高兴兴,快快乐乐,开开心心...
// \\1表示第一组 \\2表示第二组
System.out.println("高高兴兴".matches("(.)\\1(.)\\2"));// true
System.out.println("分组括号".matches("(.)\\1(.)\\2"));// false
// 叠词aabbcc格式: 呵呵哈哈嘿嘿,...
System.out.println("呵呵哈哈嘿嘿".matches("(.)\\1(.)\\2(.)\\3"));// true
System.out.println("分组括号相同".matches("(.)\\1(.)\\2(.)\\3"));// false
// 叠词abab格式: 开心开心,高兴高兴,哟西哟西,...
System.out.println("开心开心".matches("(..)\\1"));// true
System.out.println("高高兴兴".matches("(..)\\1"));// false
System.out.println("分组括号".matches("(..)\\1"));// false
}
}
String类的split()方法原型:
public String[] split(String regex)//参数regex就是一个正则表达式。可以将当前字符串中匹配regex正则表达式的符号作为"分隔符"来切割字符串。
不含预定义字符的都是字符串
代码示例:
public class Test1_split {
public static void main(String[] args) {
String str1 = "hello-world-java-php";
String[] arr1 = str1.split("-");// 就是一个字符串-
for (String s : arr1) {
System.out.println("s:"+s);
}
System.out.println("-----------");
String str2 = "hello-world-java-php";
String[] arr2 = str2.split("\\.");
for (String s : arr2) {
System.out.println("s:"+s);
}
}
}
public String replaceAll(String regex,String newStr)//参数regex就是一个正则表达式。可以将当前字符串中匹配regex正则表达式的字符串替换为newStr。
代码示例:
public class Test2_replaceAll {
public static void main(String[] args) {
String message = "我草,你他妈的,我靠,你妹的,我日";
String msg = message.replaceAll("草|他妈的|靠|妹的|日", "***");
System.out.println("msg:" + msg);
}
}
1.定义XML文件----XML的组成元素(文档声明,标签,属性,注释,转义字符,字符区)
2.使用Dom4j解析XML文件---结合XPATH路径
3.分析分析正则表达式,写点简单的正则表达---目的是为了能看懂正则表达式
String类中使用正则表达式--->matches,split,replaceAll
- 能够说出XML的作用
1.作为配置文件=----框架阶段
2.存储数据,传输数据
- 了解XML的组成元素
文档声明,标签,属性,注释,转义字符,字符区
- 能够说出有哪些XML约束技术
dtd,schema
- 能够说出解析XML文档DOM方式原理
解析器-->读取xml文档-->Dom树--->Document对象
- 能够使用dom4j解析XML文档
1.导入dom4j的jar包
2.把jar包添加到classpath路径中
3.创建解析器对象
4.使用解析器对象读取xml文件,生成Document对象
5.使用Document对象获取根标签
6.使用根标签获取子标签,....
- 能够使用xpath解析XML
1.导入dom4j和xpath的jar包
2.把jar包添加到classpath路径中
3.创建解析器对象
4.使用解析器对象读取xml文件,生成Document对象
5.使用Document对象结合xpath路径获取指定标签
- 能够理解正则表达式的作用
作为匹配规则,替换复杂的if判断操作
- 能够使用正则表达式的字符类
[] 表示匹配单个字符,^表示取反,-表示范围
1. [abc]:代表a或者b,或者c字符中的一个。
2. [^abc]:代表除a,b,c以外的任何字符。
3. [a-z]:代表a-z的所有小写字符中的一个。 左右包含
4. [A-Z]:代表A-Z的所有大写字符中的一个。
5. [0-9]:代表0-9之间的某一个数字字符。
6. [a-zA-Z0-9]:代表a-z或者A-Z或者0-9之间的任意一个字符。
7. [a-dm-p]:a 到 d 或 m 到 p之间的任意一个字符。
- 能够使用正则表达式的逻辑运算符
&& 并且
| 或者
- 能够使用正则表达式的预定义字符类
1. "." : 匹配任何字符。如果要表示一个字符点,那么就得使用\.
2. "\d":任何数字[0-9]的简写;
3. "\D":任何非数字[^0-9]的简写;
4. "\s": 空白字符:[ \t\n\x0B\f\r] 的简写
5. "\S": 非空白字符:[^\s] 的简写
6. "\w":单词字符:[a-zA-Z_0-9]的简写
7. "\W":非单词字符:[^\w]
- 能够使用正则表达式的数量词
1. X? : 0次或1次
2. X* : 0次到多次
3. X+ : 1次或多次
4. X{n} : 恰好n次
5. X{n,} : 至少n次
6. X{n,m}: n到m次(n和m都是包含的)
- 能够使用正则表达式的分组
()
- 能够在String的split方法中使用正则表达式
String[] split(String regex);
boolean matches(String regex);
String replaceAll(String regex,String newStr)