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版本的第三版。
一个标准XML文件一般由以下几部分组成:文档声明、元素、属性、注释、转义字符、字符区。
1.文档声明
<?xml version="1.0" encoding="utf-8" ?>
2.注释
<!--注释内容-->
<!--
开始,-->
结束。元素是XML中最重要的组成部分,元素也叫标签
标签分为开始标签和结束标签,开始标签<名字> 结束标签</名字>
开始标签和结束标签中间写的是标签内容,标签的内容可以是文本,也可以是其他标签
如果标签没有任何内容,那么可以定义空标签(比如:<名字/>)
标签可以嵌套,但是不能乱嵌套
一个XML文件一定有且只有一个根标签
命名规则:
不要使用XML xML xml 写样的单词
不能使用空格,冒号
命名区分大小写
数字不能开头
<?xml version="1.0" encoding="UTF-8" ?>
<person>
<name>唐三</name>
<age>年龄</age>
<aaa/>
</person>
4.属性
<?xml version="1.0" encoding="UTF-8" ?>
<person>
<name id = "001" level = '98'>唐三</name>
<age>10</age>
<aaa type = 'itheima' />
</person>
5.转义字符
因为有些特殊的字符在XML中是不会被识别的,所以在元素体或属性值中想使用这些符号就必须使用转义字符(也叫实体字符),例如:">"、"<"、"’"、"""、"&"。
字符 | 表示符号 | 含义 |
---|---|---|
< | < | 小于 |
> | > | 大于 |
& | & | 和好 |
' | ’ | 省略号 |
" | " | 引号 |
注意:严格地讲,在 XML 中仅有字符 “<“和”&” 是非法的。省略号、引号和大于号是合法的,但是把它们替换为实体引用是个好的习惯。
转义字符应用示例:
<price> 苹果的价格: price > 5 && price < 10</price>
6.字符区
CDATA 内部的所有东西都会被解析器忽略,当做文本
<![CDATA[
文本数据
]]>
快捷键:CD
<!--写步骤 -->
<>
<!>
<![]>
<![CDATA]>
<![CDATA[ 文本 ]]>
<!-- 案例 -->
<price>
<![CDATA[
苹果的价格: price > 5 && price < 10
]]>
</price>
1.根据DTD约束写XML
XML约束文档
<?xml version="1.0" encoding="UTF-8" ?>
<!--
复制内容如下到XML文件中:
<!DOCTYPE 书架 SYSTEM "bookdtd.dtd">
-->
<!--
xml文件中引入dtd约束文档:
方式一:外部本地DTD,DTD文档在本地,dtd约束文档和xml文档在同一路径下
<!DOCTYPE 根元素 SYSTEM "文件名">
方式二:外部本地DTD,DTD文档在网络上
<!DOCTYPE 根元素 PUBLIC "DTD名称" "DTD文档的URL">\
方式三:内部DTD,在XML文档内部嵌入DTD,只对当前XML有效。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE 根元素 [元素声明]>
-->
<!--
对标签层级关系的约束:
格式:<!ELEMENT 标签名 (子标签,子标签,...)>
数量词:
* 表示元素可以出现0到多个
+ 表示元素可以出现至少1个
? 表示元素可以是0或1个
, 表示元素需要按照顺序显示
| 表示元素需要选择其中的某一个
-->
<!--
对标签的约束:
格式:<!ELEMENT 标签名 标签类型>
标签类型: EMPTY(即空元素,例如<hr/>) ANY(任意类型) (#PCDATA) 字符串数据
-->
<!--
对属性的约束:
格式:
<!ATTLIST 标签名
属性名 属性类型 属性约束
属性名 属性类型 属性约束
...
>
解释:
属性类型:
CDATA :表示文本字符串
ID:表示属性值唯一,不能以数字开头
ENUMERATED (DTD没有此关键字):表示枚举,只能从枚举列表中任选其一,如(鸡肉|牛肉|猪肉|鱼肉)
属性约束:
REQUIRED:表示该属性必须出现
IMPLIED:表示该属性可有可无
FIXED:表示属性的取值为一个固定值。语法:#FIXED "固定值"
-->
<!--根标签名为书架,书架标签下至少有一个书标签 +表示至少出现一次-->
<!ELEMENT 书架 (书+)>
<!--书标签下,包含书名,做做,售价三个子标签,并且必须按照这个顺序出现-->
<!ELEMENT 书 (书名,作者,售价)>
<!--书名标签中的内容是文本数据-->
<!ELEMENT 书名 (#PCDATA)>
<!--作者标签中的内容是文本数据-->
<!ELEMENT 作者 (#PCDATA)>
<!--售价标签中的内容是文本数据-->
<!ELEMENT 售价 (#PCDATA)>
<!--
对书标签中的属性进行约束:
书标签中有一个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" 出版社="清华" type="IT">
<书名>斗罗大陆</书名>
<作者>唐家三少</作者>
<售价>99.8</售价>
</书>
<书 id="a2">
<书名>java从入门到放弃</书名>
<作者>无名氏</作者>
<售价>9.8</售价>
</书>
</书架>
例二
<?xml version = "1.0" encoding="GB2312" standalone="yes"?>
<!DOCTYPE 购物篮 [
<!ELEMENT 购物篮 (肉+)>
<!ELEMENT 肉 EMPTY>
<!ATTLIST 肉 品种 ( 鸡肉 | 牛肉 | 猪肉 | 鱼肉 ) "鸡肉">
]>
<购物篮>
<肉 品种="牛肉"></肉>
<肉 品种="牛肉"></肉>
<肉 品种="鱼肉"></肉>
<肉/>
</购物篮>.引入约束文档
内部DTD,在XML文档内部嵌入DTD,只对当前XML有效。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE 根元素 [元素声明]>><!--内部DTD-->
外部DTD—本地DTD,DTD文档在本地系统上,企业内部自己项目使用。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE 根元素 SYSTEM "文件名"><!--外部本地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">
3.schema约束写xml
schema和DTD一样, 也是一种XML文件的约束.
Schema 语言也可作为 XSD(XML Schema Definition)。
Schema约束的文件的后缀名.xsd
Schema 功能更强大,数据类型约束更完善。
Schema约束文档:
<?xml version="1.0" encoding="UTF-8" ?>
<!-- 例文档.将注释中的以下内容复制到要编写的xml的声明下面
复制内容如下到XML文件中:
<书架 xmlns="http://www.itcast.cn"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.itcast.cn bookSchema.xsd" >
-->
<xs:schema
xmlns:xs="http://www.w3.org/2001/XMLSchema"
targetNamespace="http://www.itcast.cn"
elementFormDefault="qualified">
<!--element表示元素,也就是对元素进行约束-->
<!--根标签的名称为书架-->
<xs:element name='书架'>
<!--complexType:表示标签是一个复杂标签-->
<!--书架是一个复杂标签-->
<xs:complexType>
<!--sequence表示要按照顺序出现,maxOccurs最多出现多少次,unbounded无数次,minOccurs:最少出现多少次-->
<!--书架标签的子标签必须按照顺序出现,最多出现2次,最少出现1次-->
<xs:sequence maxOccurs="2" minOccurs="1">
<!--书架的子标签的名称为书-->
<xs:element name='书'>
<!--书标签是一个复杂标签-->
<xs:complexType>
<!--书标签的子标签必须按照顺序出现-->
<xs:sequence>
<!--书标签的子标签名为书名,类型为string-->
<!--书标签的子标签名为作者,类型为string-->
<!--书标签的子标签名为售价,类型为double-->
<xs:element name='书名' type='xs:string'/>
<xs:element name='作者' type='xs:string'/>
<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
声明方式
<书架 xmlns="http://www.itcast.cn"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.itcast.cn bookSchema.xsd" >
案例1
<?xml version="1.0" encoding="UTF-8" ?>
<书架 xmlns="http://www.itcast.cn"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.itcast.cn bookSchema.xsd" >
<书 bid="1">
<书名>斗罗大陆</书名>
<作者>唐家三少</作者>
<售价>99.8</售价>
</书>
</书架>
案例2
<?xml version="1.0" encoding="UTF-8" ?>
<a:书架 xmlns:a="http://www.itcast.cn"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.itcast.cn bookSchema.xsd" >
<a:书 bid="1">
<a:书名>斗罗大陆</a:书名>
<a:作者>唐家三少</a:作者>
<a:售价>99.8</a:售价>
</a:书>
</a:书架>
XML DOM 和 HTML DOM一样,XML DOM 将整个XML文档加载到内存,生成一个DOM树,并获得一个Document对象,通过Document对象就可以对DOM进行操作。DOM中的核心概念就是节点,在XML文档中的元素、属性、文本,在DOM中都是节点!所有的节点都封装到了Document对象中。
创建解析器对象:
SAXReader sr = new SAXReader();
解析器读取文件方法:
Document doc = sr.read(String fileName);
Document的方法:
getRootElement() : 获取根元素
节点中的方法:
elements() : 获取当前元素的子元素
element(String name) : 根据元素名获取指定子元素(如果有多个就获取到第一个)
getName() : 获取元素的元素名
elementText(String name) : 获取指定子元素的文本值,参数是子元素名称
attributeValue(String name) : 获取当前元素下某个属性的值
getText() : 获取当前元素的文本值
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>
解析
// 1.创建解析器对象
SAXReader sr = new SAXReader();
// 2.使用解析器读取xml文档,生成Document对象
Document document = sr.read("day16\\src\\book.xml");
// 3.根据Document对象获取根元素
Element rootE = document.getRootElement();
System.out.println("根元素的名称:" + rootE.getName());// books
// 4.获取根元素下的所有子元素
List<Element> list1 = rootE.elements();
// 5.循环遍历根元素的所有的子元素
for (Element e1 : list1) {
System.out.println("根元素的子元素的名称:" + e1.getName());// book book
System.out.println("根元素的子元素的id属性值:" + e1.attributeValue("id"));// 0001 0002
// 获取e1元素下的所有子元素
List<Element> list2 = e1.elements();
// 循环遍历list2
for (Element e2 : list2) {
System.out.println("book下的子元素名:" + e2.getName());// name author sale
System.out.println("book下的子元素中的文本:" + e2.getText());// name author sale
}
System.out.println("==================================");
}
// 5.获取根元素下的book子元素(就获取第一个)
Element bookE = rootE.element("book");
System.out.println(bookE.getName());// book
System.out.println(bookE.attributeValue("id"));// 0001
// 6.获取bookE元素下的author子元素的文本
String text = bookE.elementText("author");
System.out.println(text);// 张孝祥
XPath 使用路径表达式来选取HTML\XML 文档中的元素节点或属性节点。节点是通过沿着路径 (path) 来选取的。XPath在解析HTML\XML文档方面提供了独树一帜的路径思想。
1.XPath使用步骤
步骤1:导入jar包(dom4j和jaxen-1.1-beta-6.jar)
步骤2:通过dom4j的SaxReader解析器对象,获取Document对象
步骤3: 利用Xpath提供的api,结合xpaht的语法完成选取XML文档元素节点进行解析操作。
document常用的api
XPath表达式,就是用于选取HTML文档中节点的表达式字符串。
获取XML文档节点元素一共有如下4种XPath语法方式:
3.获取不同节点语法
获取类型 | 语法代码 |
---|---|
获取元素节点 | 元素名称 |
获取属性节点 | @属性名称 |
4. 绝对路径表达式
以/开头的路径叫做是绝对路径,绝对路径要从根元素开始写
// 创建解析器
SAXReader sr = new SAXReader();
// 读取xml 获得document对象
Document document = sr.read("day/src/tianqi.xml");
// 得到根元素
Element rootE = document.getRootElement();
System.out.println(rootE);
// 绝对路径: 获取深圳 湿度
Node node = rootE.selectSingleNode("/天气预报/深圳/湿度");
System.out.println(node.getName());// 湿度
System.out.println(node.getText());// 50%
5.相对路径表达式
相对路径就是相对当前节点元素位置继续查找节点,不以/开头, …/ 表示上一个元素, ./表示当前元素
// 创建解析器
SAXReader sr = new SAXReader();
// 读取xml 获得document对象
Document document = sr.read("day22/src/tianqi.xml");
// 得到根元素
Element rootE = document.getRootElement();
System.out.println(rootE);
// 相对路径: 获取深圳 湿度
Node node = rootE.selectSingleNode("./深圳/湿度");
System.out.println(node.getName());// 湿度
System.out.println(node.getText());// 50%
//用绝对路径的方式获取“温度”
Node node2 = document.selectSingleNode("/天气预报/北京/温度");
// 相对路径: 获取北京 湿度
Node node3 = node2.selectSingleNode("../湿度");
System.out.println(node3.getName());// 湿度
System.out.println(node3.getText());// 20%
6、全文搜索表达式
代表不论中间有多少层,直接获取所有子元素中满足条件的元素
// 创建解析器
SAXReader sr = new SAXReader();
// 读取xml 获得document对象
Document document = sr.read("day22/src/tianqi.xml");
// 得到根元素
Element rootE = document.getRootElement();
System.out.println(rootE);
// 获取天气预报里的所有湿度,不论有多少层
List<Element> list = rootE.selectNodes("//湿度");
for (Element e : list) {
System.out.println(e.getName()+","+e.getText());
}
7.谓语(条件筛选)
谓语,又称为条件筛选方式,就是根据条件过滤判断进行选取节点
格式:
String xpath1="//元素[@attr1=value]";//获取元素属性attr1=value的元素
String xpath2="//元素[@attr1>value]/@attr1";//获取元素属性attr1>value的d的所有attr1的值
String xpath3="//元素[@attr1=value]/text()";//获取符合条件元素体的自有文本数据
String xpath4="//元素[@attr1=value]/html()";//获取符合条件元素体的自有html代码数据。
String xpath3="//元素[@attr1=value]/allText()";//获取符合条件元素体的所有文本数据(包含子元素里面的文本)
// 创建解析器
SAXReader sr = new SAXReader();
// 读取xml 获得document对象
Document document = sr.read("day22/src/tianqi.xml");
// 得到根元素
Element rootE = document.getRootElement();
System.out.println(rootE);
// 获取最高温度中属性名是level 属性值是A的元素
List<Element> list = rootE.selectNodes("//最高温度[@level='C']");
for (Element e : list) {
System.out.println(e.getName()+","+e.getText());
}
正则表达式其实就是一个匹配规则,用来替换之前复杂的if结构判断,在Java中,我们经常需要验证一些字符串,是否符合规则, 例如:校验qq号码是否正确,手机号码是否正确,邮箱是否正确等等。那么如果使用if就会很麻烦, 而正则表达式就是用来验证各种字符串的规则。它内部描述了一些规则,我们可以验证用户输入的字符串是否匹配这个规则。
例子
public class Demo {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("请输入你的QQ号码:");
String qq = sc.next();
System.out.println(checkQQ2(qq));
}
//使用正则表达式验证
private static boolean checkQQ2(String qq){
String regex = "[1-9]\\d{4,14}";//正则表达式
return qq.matches(regex);
}
}
上面程序checkQQ2()方法中String类型的变量regex就存储了一个"正则表达式 ",而这个正则表达式就描述了我们需要的三个规则。matches()方法是String类的一个方法,用于接收一个正则表达式,并将"本对象"与参数"正则表达式"进行匹配,如果本对象符合正则表达式的规则,则返回true,否则返回false。
1.正则表达式-字符类
[] 表示匹配单个字符 , ^ 取反 , - 范围
String str = "ead";
//1.验证str是否以h开头,以d结尾,中间是a,e,i,o,u中某个字符
System.out.println(str.matches("h[aeiou]d"));// false
System.out.println("hed".matches("h[aeiou]d"));// true
System.out.println("heod".matches("h[aeiou]d"));// false
System.out.println("==========================================");
//2.验证str是否以h开头,以d结尾,中间不是a,e,i,o,u中的某个字符
System.out.println(str.matches("h[^aeiou]d"));// false
System.out.println("hed".matches("h[^aeiou]d"));// false
System.out.println("hbd".matches("h[^aeiou]d"));// true
System.out.println("==========================================");
//3.验证str是否a-z的任何一个小写字符开头,后跟ad
System.out.println(str.matches("[a-z]ad"));// true
System.out.println("Aad".matches("[a-z]ad"));// false
System.out.println("==========================================");
//4.验证str是否以a-d或者m-p之间某个字符开头,后跟ad
System.out.println(str.matches("[a-dm-p]ad"));//false
System.out.println("bad".matches("[a-dm-p]ad"));// true
System.out.println("nad".matches("[a-dm-p]ad"));// true
2.正则表达式-逻辑运算符
String str = "had";
//1.要求字符串是小写辅音字符开头,后跟ad 除了a,e,i,o,u之外,其他的都是辅音字母
System.out.println(str.matches("[a-z&&[^aeiou]]ad"));// true
System.out.println("aad".matches("[a-z&&[^aeiou]]ad"));// false
System.out.println("Aad".matches("[a-z&&[^aeiou]]ad"));// false
System.out.println("========================");
//2.要求字符串是aeiou中的某个字符开头,后跟ad
System.out.println(str.matches("[aeiou]ad"));// false
System.out.println(str.matches("[a|e|i|o|u]ad"));// false
System.out.println("aad".matches("[aeiou]ad"));// true
System.out.println("aad".matches("[a|e|i|o|u]ad"));// true
3.正则表达式-预定义字符
String str = "258";
//1.验证str是否3位数字
System.out.println(str.matches("\\d\\d\\d"));// true
System.out.println("25".matches("\\d\\d\\d"));// false
System.out.println("+===================================");
//2.验证手机号:1开头,第二位:3/5/8,剩下9位都是0-9的数字
System.out.println(str.matches("1[358]\\d\\d\\d\\d\\d\\d\\d\\d\\d"));// false
System.out.println("13838381234".matches("1[358]\\d\\d\\d\\d\\d\\d\\d\\d\\d"));// true
System.out.println("14838381234".matches("1[358]\\d\\d\\d\\d\\d\\d\\d\\d\\d"));// false
System.out.println("+===================================");
//3.验证字符串是否以h开头,以d结尾,中间是任何字符
System.out.println(str.matches("h.d"));// false
System.out.println("h%d".matches("h.d"));// true
System.out.println("h#d".matches("h.d"));// true
System.out.println("+===================================");
//4.验证str是否是:h.d
System.out.println("h.d".matches("h.d"));// true
System.out.println("had".matches("h.d"));// true
System.out.println("h.d".matches("h\\.d"));// true
System.out.println("had".matches("h\\.d"));// false
4.正则表达式-数量词
//1.验证str是否是三位数字
System.out.println("123".matches("\\d{3}"));// true
System.out.println("12".matches("\\d{3}"));// false
System.out.println("1234".matches("\\d{3}"));// false
System.out.println("===================================");
//2.验证str是否是多位数字
System.out.println("12".matches("\\d{2,3}"));// true
System.out.println("123".matches("\\d{2,3}"));// true
System.out.println("1223".matches("\\d{2,3}"));// false
System.out.println("1".matches("\\d+"));// true
System.out.println("12".matches("\\d+"));// true
System.out.println("123".matches("\\d+"));// true
System.out.println("1234".matches("\\d+"));// true
System.out.println("===================================");
//3.验证str是否是手机号:1).第一位为1 2).第二位是3,5,8 3).后面9位都是数字
System.out.println("13838381234".matches("1[358]\\d{9}"));// true
System.out.println("14838381234".matches("1[358]\\d{9}"));// false
System.out.println("===================================");
//4.验证qq号码:1).5--15位;2).全部是数字;3).第一位不是0
System.out.println("123456".matches("[1-9]\\d{4,14}"));// true
System.out.println("023456".matches("[1-9]\\d{4,14}"));// false
System.out.println("123".matches("[1-9]\\d{4,14}"));// false
5.正则表达式-分组括号( )
String str = "DG8FV-B9TKY-FRT9J-99899-XPQ4G";
// 分成5组: 前面4组的规则是一样的 后面一组单独规则
System.out.println(str.matches("([A-Z0-9]{5}-){4}[A-Z0-9]{5}"));
// xxyy
// 扩展:正则表达式匹配叠词
// 哈哈,呵呵,嘿嘿,XX (.)表示第一组,\\1表示第一组
System.out.println("哈哈".matches("(.)\\1"));//true
System.out.println("呵呵".matches("(.)\\1"));//true
System.out.println("嘿嘿".matches("(.)\\1"));//true
System.out.println("嘿哈".matches("(.)\\1"));// false
// (.)表示第一组,\\1表示第一组,{3}表示\\1出现3次
System.out.println("哈哈哈哈".matches("(.)\\1{3}"));//true
System.out.println("呵呵呵呵".matches("(.)\\1{3}"));//true
System.out.println("嘿嘿嘿嘿".matches("(.)\\1{3}"));//true
System.out.println("===================================");
// 高高兴兴,逼逼赖赖,XXYY
// \\1表示第一组,\\2表示第二组,\\3表示第三组....
System.out.println("高高兴兴".matches("(.)\\1(.)\\2"));//true
System.out.println("逼逼赖赖".matches("(.)\\1(.)\\2"));//true
System.out.println("===================================");
// 快乐快乐,哔哩哔哩,XYXY
System.out.println("快乐快乐".matches("(..)\\1"));//true
System.out.println("哔哩哔哩".matches("(..)\\1"));//true
1.String的split方法中使用正则表达式
String类的split()方法原型:
public String[] split(String regex)//参数regex就是一个正则表达式。可以将当前字符串中匹配regex正则表达式的符号作为"分隔符"来切割字符串。
String str = "18 4 567 99 56";
String[] strArray = str.split(" +");
for (int i = 0; i < strArray.length; i++) {
System.out.println(strArray[i]);
}
2.String类的replaceAll方法中使用正则表达式
String类的replaceAll()方法原型:
public String replaceAll(String regex,String newStr)//参数regex就是一个正则表达式。可以将当前字符串中匹配regex正则表达式的字符串替换为newStr。
//将下面字符串中的"数字"替换为"*"
String str = "jfdk432jfdk2jk24354j47jk5l31324";
System.out.println(str.replaceAll("\\d+", "*"));