Java 正则表达式 - 菜鸟教程

文章推薦指數: 80 %
投票人數:10人

Pattern 类:. pattern 对象是一个正则表达式的编译表示。

· Matcher 类:. Matcher 对象是对输入字符串进行解释和匹配操作的引擎。

· PatternSyntaxException:. 菜鸟教程--学的不仅是技术,更是梦想! 首页 HTML CSS JavaScript Vue Bootstrap NodeJS Python3 Python2 Java C C++ C# Go SQL Linux jQuery 本地书签 首页 HTML CSS JS 本地书签 Search Python3教程 Python2教程 Vue3教程 vue2教程 Bootstrap3教程 Bootstrap4教程 Bootstrap5教程 Bootstrap2教程 Java教程 Java教程 Java简介 Java开发环境配置 Java基础语法 Java对象和类 Java基本数据类型 Java变量类型 Java修饰符 Java运算符 Java循环结构 Java条件语句 Javaswitchcase JavaNumber&Math类 JavaCharacter类 JavaString类 JavaStringBuffer Java数组 Java日期时间 Java正则表达式 Java方法 JavaStream、File、IO JavaScanner类 Java异常处理 Java面向对象 Java继承 JavaOverride/Overload Java多态 Java抽象类 Java封装 Java接口 Java枚举 Java包(package) Java高级教程 Java数据结构 Java集合框架 JavaArrayList JavaLinkedList JavaHashSet JavaHashMap JavaIterator JavaObject Java泛型 Java序列化 Java网络编程 Java发送邮件 Java多线程编程 JavaApplet基础 Java文档注释 Java实例 Java8新特性 JavaMySQL连接 Java9新特性 Java测验 Java日期时间 Java方法 Java正则表达式 正则表达式定义了字符串的模式。

正则表达式可以用来搜索、编辑或处理文本。

正则表达式并不仅限于某一种语言,但是在每种语言中有细微的差别。

正则表达式实例 一个字符串其实就是一个简单的正则表达式,例如HelloWorld正则表达式匹配"HelloWorld"字符串。

.(点号)也是一个正则表达式,它匹配任何一个字符如:"a"或"1"。

下表列出了一些正则表达式的实例及描述: 正则表达式 描述 thisistext 匹配字符串"thisistext" this\s+is\s+text 注意字符串中的\s+。

匹配单词"this"后面的\s+可以匹配多个空格,之后匹配is字符串,再之后\s+匹配多个空格然后再跟上text字符串。

可以匹配这个实例:thisistext ^\d+(\.\d+)? ^定义了以什么开始 \d+匹配一个或多个数字 ?设置括号内的选项是可选的 \.匹配"." 可以匹配的实例:"5","1.5"和"2.21"。

Java正则表达式和Perl的是最为相似的。

java.util.regex包主要包括以下三个类: Pattern类:pattern对象是一个正则表达式的编译表示。

Pattern类没有公共构造方法。

要创建一个Pattern对象,你必须首先调用其公共静态编译方法,它返回一个Pattern对象。

该方法接受一个正则表达式作为它的第一个参数。

Matcher类:Matcher对象是对输入字符串进行解释和匹配操作的引擎。

与Pattern类一样,Matcher也没有公共构造方法。

你需要调用Pattern对象的matcher方法来获得一个Matcher对象。

PatternSyntaxException:PatternSyntaxException是一个非强制异常类,它表示一个正则表达式模式中的语法错误。

以下实例中使用了正则表达式.*runoob.*用于查找字符串中是否包了runoob子串: 实例 importjava.util.regex.*; classRegexExample1{ publicstaticvoidmain(String[]args){ Stringcontent="Iamnoob"+ "fromrunoob.com."; Stringpattern=".*runoob.*"; booleanisMatch=Pattern.matches(pattern,content); System.out.println("字符串中是否包含了'runoob'子字符串?"+isMatch); } } 实例输出结果为: 字符串中是否包含了'runoob'子字符串?true 捕获组 捕获组是把多个字符当一个单独单元进行处理的方法,它通过对括号内的字符分组来创建。

例如,正则表达式(dog)创建了单一分组,组里包含"d","o",和"g"。

捕获组是通过从左至右计算其开括号来编号。

例如,在表达式((A)(B(C))),有四个这样的组: ((A)(B(C))) (A) (B(C)) (C) 可以通过调用matcher对象的groupCount方法来查看表达式有多少个分组。

groupCount方法返回一个int值,表示matcher对象当前有多个捕获组。

还有一个特殊的组(group(0)),它总是代表整个表达式。

该组不包括在groupCount的返回值中。

实例 下面的例子说明如何从一个给定的字符串中找到数字串: RegexMatches.java文件代码: importjava.util.regex.Matcher; importjava.util.regex.Pattern; publicclassRegexMatches { publicstaticvoidmain(String[]args){ //按指定模式在字符串查找 Stringline="ThisorderwasplacedforQT3000!OK?"; Stringpattern="(\\D*)(\\d+)(.*)"; //创建Pattern对象 Patternr=Pattern.compile(pattern); //现在创建matcher对象 Matcherm=r.matcher(line); if(m.find()){ System.out.println("Foundvalue:"+m.group(0)); System.out.println("Foundvalue:"+m.group(1)); System.out.println("Foundvalue:"+m.group(2)); System.out.println("Foundvalue:"+m.group(3)); }else{ System.out.println("NOMATCH"); } } } 以上实例编译运行结果如下: Foundvalue:ThisorderwasplacedforQT3000!OK? Foundvalue:ThisorderwasplacedforQT Foundvalue:3000 Foundvalue:!OK? 正则表达式语法 在其他语言中,\\表示:我想要在正则表达式中插入一个普通的(字面上的)反斜杠,请不要给它任何特殊的意义。

在Java中,\\表示:我要插入一个正则表达式的反斜线,所以其后的字符具有特殊的意义。

所以,在其他的语言中(如Perl),一个反斜杠\就足以具有转义的作用,而在Java中正则表达式中则需要有两个反斜杠才能被解析为其他语言中的转义作用。

也可以简单的理解在Java的正则表达式中,两个\\代表其他语言中的一个\,这也就是为什么表示一位数字的正则表达式是\\d,而表示一个普通的反斜杠是\\。

System.out.print("\\");//输出为\ System.out.print("\\\\");//输出为\\ 字符说明\ 将下一字符标记为特殊字符、文本、反向引用或八进制转义符。

例如,n匹配字符n。

\n匹配换行符。

序列\\\\匹配\\,\\(匹配(。

^匹配输入字符串开始的位置。

如果设置了RegExp对象的Multiline属性,^还会与"\n"或"\r"之后的位置匹配。

$匹配输入字符串结尾的位置。

如果设置了RegExp对象的Multiline属性,$还会与"\n"或"\r"之前的位置匹配。

*零次或多次匹配前面的字符或子表达式。

例如,zo*匹配"z"和"zoo"。

*等效于{0,}。

+一次或多次匹配前面的字符或子表达式。

例如,"zo+"与"zo"和"zoo"匹配,但与"z"不匹配。

+等效于{1,}。

?零次或一次匹配前面的字符或子表达式。

例如,"do(es)?"匹配"do"或"does"中的"do"。

?等效于{0,1}。

{n}n是非负整数。

正好匹配n次。

例如,"o{2}"与"Bob"中的"o"不匹配,但与"food"中的两个"o"匹配。

{n,}n是非负整数。

至少匹配n次。

例如,"o{2,}"不匹配"Bob"中的"o",而匹配"foooood"中的所有o。

"o{1,}"等效于"o+"。

"o{0,}"等效于"o*"。

{n,m}m和n是非负整数,其中n<=m。

匹配至少n次,至多m次。

例如,"o{1,3}"匹配"fooooood"中的头三个o。

'o{0,1}'等效于'o?'。

注意:您不能将空格插入逗号和数字之间。

?当此字符紧随任何其他限定符(*、+、?、{n}、{n,}、{n,m})之后时,匹配模式是"非贪心的"。

"非贪心的"模式匹配搜索到的、尽可能短的字符串,而默认的"贪心的"模式匹配搜索到的、尽可能长的字符串。

例如,在字符串"oooo"中,"o+?"只匹配单个"o",而"o+"匹配所有"o"。

.匹配除"\r\n"之外的任何单个字符。

若要匹配包括"\r\n"在内的任意字符,请使用诸如"[\s\S]"之类的模式。

(pattern)匹配pattern并捕获该匹配的子表达式。

可以使用$0…$9属性从结果"匹配"集合中检索捕获的匹配。

若要匹配括号字符(),请使用"\("或者"\)"。

(?:pattern)匹配pattern但不捕获该匹配的子表达式,即它是一个非捕获匹配,不存储供以后使用的匹配。

这对于用"or"字符(|)组合模式部件的情况很有用。

例如,'industr(?:y|ies)是比'industry|industries'更经济的表达式。

(?=pattern)执行正向预测先行搜索的子表达式,该表达式匹配处于匹配pattern的字符串的起始点的字符串。

它是一个非捕获匹配,即不能捕获供以后使用的匹配。

例如,'Windows(?=95|98|NT|2000)'匹配"Windows2000"中的"Windows",但不匹配"Windows3.1"中的"Windows"。

预测先行不占用字符,即发生匹配后,下一匹配的搜索紧随上一匹配之后,而不是在组成预测先行的字符后。

(?!pattern)执行反向预测先行搜索的子表达式,该表达式匹配不处于匹配pattern的字符串的起始点的搜索字符串。

它是一个非捕获匹配,即不能捕获供以后使用的匹配。

例如,'Windows(?!95|98|NT|2000)'匹配"Windows3.1"中的"Windows",但不匹配"Windows2000"中的"Windows"。

预测先行不占用字符,即发生匹配后,下一匹配的搜索紧随上一匹配之后,而不是在组成预测先行的字符后。

x|y匹配x或y。

例如,'z|food'匹配"z"或"food"。

'(z|f)ood'匹配"zood"或"food"。

[xyz]字符集。

匹配包含的任一字符。

例如,"[abc]"匹配"plain"中的"a"。

[^xyz]反向字符集。

匹配未包含的任何字符。

例如,"[^abc]"匹配"plain"中"p","l","i","n"。

[a-z]字符范围。

匹配指定范围内的任何字符。

例如,"[a-z]"匹配"a"到"z"范围内的任何小写字母。

[^a-z]反向范围字符。

匹配不在指定的范围内的任何字符。

例如,"[^a-z]"匹配任何不在"a"到"z"范围内的任何字符。

\b匹配一个字边界,即字与空格间的位置。

例如,"er\b"匹配"never"中的"er",但不匹配"verb"中的"er"。

\B非字边界匹配。

"er\B"匹配"verb"中的"er",但不匹配"never"中的"er"。

\cx匹配x指示的控制字符。

例如,\cM匹配Control-M或回车符。

x的值必须在A-Z或a-z之间。

如果不是这样,则假定c就是"c"字符本身。

\d数字字符匹配。

等效于[0-9]。

\D非数字字符匹配。

等效于[^0-9]。

\f换页符匹配。

等效于\x0c和\cL。

\n换行符匹配。

等效于\x0a和\cJ。

\r匹配一个回车符。

等效于\x0d和\cM。

\s匹配任何空白字符,包括空格、制表符、换页符等。

与[ \f\n\r\t\v]等效。

\S匹配任何非空白字符。

与[^ \f\n\r\t\v]等效。

\t制表符匹配。

与\x09和\cI等效。

\v垂直制表符匹配。

与\x0b和\cK等效。

\w匹配任何字类字符,包括下划线。

与"[A-Za-z0-9_]"等效。

\W与任何非单词字符匹配。

与"[^A-Za-z0-9_]"等效。

\xn匹配n,此处的n是一个十六进制转义码。

十六进制转义码必须正好是两位数长。

例如,"\x41"匹配"A"。

"\x041"与"\x04"&"1"等效。

允许在正则表达式中使用ASCII代码。

\num匹配num,此处的num是一个正整数。

到捕获匹配的反向引用。

例如,"(.)\1"匹配两个连续的相同字符。

\n标识一个八进制转义码或反向引用。

如果\n前面至少有n个捕获子表达式,那么n是反向引用。

否则,如果n是八进制数(0-7),那么n是八进制转义码。

\nm标识一个八进制转义码或反向引用。

如果\nm前面至少有nm个捕获子表达式,那么nm是反向引用。

如果\nm前面至少有n个捕获,则n是反向引用,后面跟有字符m。

如果两种前面的情况都不存在,则\nm匹配八进制值nm,其中n和m是八进制数字(0-7)。

\nml当n是八进制数(0-3),m和l是八进制数(0-7)时,匹配八进制转义码nml。

\un匹配n,其中n是以四位十六进制数表示的Unicode字符。

例如,\u00A9匹配版权符号(©)。

根据JavaLanguageSpecification的要求,Java源代码的字符串中的反斜线被解释为Unicode转义或其他字符转义。

因此必须在字符串字面值中使用两个反斜线,表示正则表达式受到保护,不被Java字节码编译器解释。

例如,当解释为正则表达式时,字符串字面值"\b"与单个退格字符匹配,而"\\b"与单词边界匹配。

字符串字面值"\(hello\)"是非法的,将导致编译时错误;要与字符串(hello)匹配,必须使用字符串字面值"\\(hello\\)"。

Matcher类的方法 索引方法 索引方法提供了有用的索引值,精确表明输入字符串中在哪能找到匹配: 序号 方法及说明 1 publicintstart() 返回以前匹配的初始索引。

2 publicintstart(intgroup)  返回在以前的匹配操作期间,由给定组所捕获的子序列的初始索引 3 publicintend() 返回最后匹配字符之后的偏移量。

4 publicintend(intgroup) 返回在以前的匹配操作期间,由给定组所捕获子序列的最后字符之后的偏移量。

查找方法 查找方法用来检查输入字符串并返回一个布尔值,表示是否找到该模式: 序号 方法及说明 1 publicbooleanlookingAt()  尝试将从区域开头开始的输入序列与该模式匹配。

2 publicbooleanfind() 尝试查找与该模式匹配的输入序列的下一个子序列。

3 publicbooleanfind(intstart) 重置此匹配器,然后尝试查找匹配该模式、从指定索引开始的输入序列的下一个子序列。

4 publicbooleanmatches() 尝试将整个区域与模式匹配。

替换方法 替换方法是替换输入字符串里文本的方法: 序号 方法及说明 1 publicMatcherappendReplacement(StringBuffersb,Stringreplacement) 实现非终端添加和替换步骤。

2 publicStringBufferappendTail(StringBuffersb) 实现终端添加和替换步骤。

3 publicStringreplaceAll(Stringreplacement)  替换模式与给定替换字符串相匹配的输入序列的每个子序列。

4 publicStringreplaceFirst(Stringreplacement)  替换模式与给定替换字符串匹配的输入序列的第一个子序列。

5 publicstaticStringquoteReplacement(Strings) 返回指定字符串的字面替换字符串。

这个方法返回一个字符串,就像传递给Matcher类的appendReplacement方法一个字面字符串一样工作。

start和end方法 下面是一个对单词"cat"出现在输入字符串中出现次数进行计数的例子: RegexMatches.java文件代码: importjava.util.regex.Matcher; importjava.util.regex.Pattern; publicclassRegexMatches { privatestaticfinalStringREGEX="\\bcat\\b"; privatestaticfinalStringINPUT= "catcatcatcattiecat"; publicstaticvoidmain(String[]args){ Patternp=Pattern.compile(REGEX); Matcherm=p.matcher(INPUT);//获取matcher对象 intcount=0; while(m.find()){ count++; System.out.println("Matchnumber"+count); System.out.println("start():"+m.start()); System.out.println("end():"+m.end()); } } } 以上实例编译运行结果如下: Matchnumber1 start():0 end():3 Matchnumber2 start():4 end():7 Matchnumber3 start():8 end():11 Matchnumber4 start():19 end():22 可以看到这个例子是使用单词边界,以确保字母"c""a""t"并非仅是一个较长的词的子串。

它也提供了一些关于输入字符串中匹配发生位置的有用信息。

Start方法返回在以前的匹配操作期间,由给定组所捕获的子序列的初始索引,end方法最后一个匹配字符的索引加1。

matches和lookingAt方法 matches和lookingAt方法都用来尝试匹配一个输入序列模式。

它们的不同是matches要求整个序列都匹配,而lookingAt不要求。

lookingAt方法虽然不需要整句都匹配,但是需要从第一个字符开始匹配。

这两个方法经常在输入字符串的开始使用。

我们通过下面这个例子,来解释这个功能: RegexMatches.java文件代码: importjava.util.regex.Matcher; importjava.util.regex.Pattern; publicclassRegexMatches { privatestaticfinalStringREGEX="foo"; privatestaticfinalStringINPUT="fooooooooooooooooo"; privatestaticfinalStringINPUT2="ooooofoooooooooooo"; privatestaticPatternpattern; privatestaticMatchermatcher; privatestaticMatchermatcher2; publicstaticvoidmain(String[]args){ pattern=Pattern.compile(REGEX); matcher=pattern.matcher(INPUT); matcher2=pattern.matcher(INPUT2); System.out.println("CurrentREGEXis:"+REGEX); System.out.println("CurrentINPUTis:"+INPUT); System.out.println("CurrentINPUT2is:"+INPUT2); System.out.println("lookingAt():"+matcher.lookingAt()); System.out.println("matches():"+matcher.matches()); System.out.println("lookingAt():"+matcher2.lookingAt()); } } 以上实例编译运行结果如下: CurrentREGEXis:foo CurrentINPUTis:fooooooooooooooooo CurrentINPUT2is:ooooofoooooooooooo lookingAt():true matches():false lookingAt():false replaceFirst和replaceAll方法 replaceFirst和replaceAll方法用来替换匹配正则表达式的文本。

不同的是,replaceFirst替换首次匹配,replaceAll替换所有匹配。

下面的例子来解释这个功能: RegexMatches.java文件代码: importjava.util.regex.Matcher; importjava.util.regex.Pattern; publicclassRegexMatches { privatestaticStringREGEX="dog"; privatestaticStringINPUT="Thedogsaysmeow."+ "Alldogssaymeow."; privatestaticStringREPLACE="cat"; publicstaticvoidmain(String[]args){ Patternp=Pattern.compile(REGEX); //getamatcherobject Matcherm=p.matcher(INPUT); INPUT=m.replaceAll(REPLACE); System.out.println(INPUT); } } 以上实例编译运行结果如下: Thecatsaysmeow.Allcatssaymeow. appendReplacement和appendTail方法 Matcher类也提供了appendReplacement和appendTail方法用于文本替换: 看下面的例子来解释这个功能: RegexMatches.java文件代码: importjava.util.regex.Matcher; importjava.util.regex.Pattern; publicclassRegexMatches { privatestaticStringREGEX="a*b"; privatestaticStringINPUT="aabfooaabfooabfoobkkk"; privatestaticStringREPLACE="-"; publicstaticvoidmain(String[]args){ Patternp=Pattern.compile(REGEX); //获取matcher对象 Matcherm=p.matcher(INPUT); StringBuffersb=newStringBuffer(); while(m.find()){ m.appendReplacement(sb,REPLACE); } m.appendTail(sb); System.out.println(sb.toString()); } } 以上实例编译运行结果如下: -foo-foo-foo-kkk PatternSyntaxException类的方法 PatternSyntaxException是一个非强制异常类,它指示一个正则表达式模式中的语法错误。

PatternSyntaxException类提供了下面的方法来帮助我们查看发生了什么错误。

序号 方法及说明 1 publicStringgetDescription() 获取错误的描述。

2 publicintgetIndex()  获取错误的索引。

3 publicStringgetPattern() 获取错误的正则表达式模式。

4 publicStringgetMessage() 返回多行字符串,包含语法错误及其索引的描述、错误的正则表达式模式和模式中错误索引的可视化指示。

Java日期时间 Java方法 4篇笔记 写笔记 #0   豆妮的小奴隶  861***[email protected]正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个"规则字符串",这个"规则字符串"用来表达对字符串的一种过滤逻辑。

给定一个正则表达式和另一个字符串,我们可以达到如下的目的: 1.给定的字符串是否符合正则表达式的过滤逻辑(称作"匹配"); 2.可以通过正则表达式,从字符串中获取我们想要的特定部分。

正则表达式的特点是: 1.灵活性、逻辑性和功能性非常的强; 2.可以迅速地用极简单的方式达到字符串的复杂控制。

3.对于刚接触的人来说,比较晦涩难懂。

注意:正则表达式写好后,没有错对之分,返回结果只是true和false 校验QQ号,要求:必须是5~15位数字,0不能开头。

没有正则表达式之前 publicclassregex{ publicstaticvoidmain(String[]args){         checkQQ("0123134"); } publicstaticvoidcheckQQ(Stringqq) {         intlen=qq.length();         if(len>=5&&len<=15)         {             if(!qq.startsWith("0"))             {                 try                 {                     longl=Long.parseLong(qq);                     System.out.println("qq:"+l);                 }                 catch(NumberFormatExceptione)                 {                     System.out.println("出现非法字符");                 }             }             else                 System.out.println("不可以0开头");         }         else             System.out.println("QQ号长度错误");         } } 使用正则表达式之后的代码: publicclassregex{ publicstaticvoidmain(String[]args){ checkQQ2("0123134"); } publicstaticvoidcheckQQ2(Stringqq){ Stringreg="[1-9][0-9]{4,14}"; System.out.println(qq.matches(reg)?"合法qq":"非法qq"); } }豆妮的小奴隶   豆妮的小奴隶  861***[email protected]年前(2017-11-21) #0   yimkong  136***[email protected]关于小括号分组,之前看马士兵视频的时候学到的,数左小括号"(",第几个就是第几组,可以将前面指定括号的规则在后面复用: //小括号分组:数左边的小括号第几个就是第几组 Patternp=Pattern.compile("(\\d{2})([a-z]{2,3})"); Matcherm=p.matcher("33aa-32sdy-29ssc"); while(m.find()){ System.out.println(m.group(2));//每次匹配获取第二组内容 } /* 结果: aa sdy ssc */ //向前引用: Patternp=Pattern.compile("(\\d(\\d))\\2"); Matchermatcher=p.matcher("211"); System.out.println(matcher.matches()); //结果:true //解释:"\\2"代表引用前面的第2组匹配的值yimkong   yimkong  136***[email protected]年前(2018-01-02) #0   jinling  103***[email protected]  参考地址22matcher.appendReplacement(sb,replaceContent);与matcher.appendTail(sb); appendReplacement方法:sb是一个StringBuffer,replaceContext待替换的字符串,这个方法会把匹配到的内容替换为replaceContext,并且把从上次替换的位置到这次替换位置之间的字符串也拿到,然后,加上这次替换后的结果一起追加到StringBuffer里(假如这次替换是第一次替换,那就是只追加替换后的字符串啦)。

appendTail方法:sb是一个StringBuffer,这个方法是把最后一次匹配到内容之后的字符串追加到StringBuffer中。

两个方法一起使用就可以达到所有替换或者替换第一个: 所有替换: while(m.find()){ m.appendReplacement(sb,replaceContext); } .appendTail(sb); 替换第一个: if(matcher.find()){ matcher.appendReplacement(sb,replaceContext); } matcher.appendTail(sb);jinling   jinling  103***[email protected]  参考地址5年前(2018-01-07) #0   H2凸  198***[email protected]使用正则表达式查找字符串中数字出现的位置: importjava.util.regex.Matcher; importjava.util.regex.Pattern; publicclassPrimitiveTypeTest{ //查找数字,返回位置 privatestaticfinalStringregex="\\d+"; privatestaticfinalStringinput="0catcattcatrecatcat9"; publicstaticvoidmain(String[]Args){ Patternp=Pattern.compile(regex); Matcherq=p.matcher(input); intcount=0; while(q.find()){ count++; System.out.println("matchnumber"+count); System.out.println("start()"+q.start()); System.out.println("end()"+q.end()); } } }H2凸   H2凸  198***[email protected]年前(2018-05-29) 点我分享笔记 取消 分享笔记 昵称昵称(必填) 邮箱邮箱(必填) 引用地址引用地址 分类导航 HTML/CSSHTML教程HTML5教程CSS教程CSS3教程Bootstrap3教程Bootstrap4教程Bootstrap5教程FontAwesome教程Foundation教程JavaScriptJavaScript教程HTMLDOM教程jQuery教程AngularJS教程AngularJS2教程Vue.js教程Vue3教程React教程TypeScript教程jQueryUI教程jQueryEasyUI教程Node.js教程AJAX教程JSON教程Echarts教程Highcharts教程Google地图教程服务端Python教程Python2.x教程Linux教程Docker教程Ruby教程Java教程C教程C++教程Perl教程Servlet教程JSP教程Lua教程Rust教程Scala教程Go教程PHP教程Django教程Zookeeper教程设计模式正则表达式Maven教程Verilog教程ASP教程AppML教程VBScript教程数据库SQL教程MySQL教程PostgreSQL教程SQLite教程MongoDB教程Redis教程Memcached教程数据分析Python教程NumPy教程Pandas教程Matplotlib教程Scipy教程R教程Julia教程移动端Android教程Swift教程jQueryMobile教程ionic教程Kotlin教程XML教程XML教程DTD教程XMLDOM教程XSLT教程XPath教程XQuery教程XLink教程XPointer教程XMLSchema教程XSL-FO教程SVG教程ASP.NETASP.NET教程C#教程WebPages教程Razor教程MVC教程WebForms教程WebServiceWebService教程WSDL教程SOAP教程RSS教程RDF教程开发工具Eclipse教程Git教程Svn教程Markdown教程网站建设HTTP教程网站建设指南浏览器信息网站主机教程TCP/IP教程W3C教程网站品质 Advertisement 反馈/建议 在线实例 ·HTML实例 ·CSS实例 ·JavaScript实例 ·Ajax实例 ·jQuery实例 ·XML实例 ·Java实例 字符集&工具 ·HTML字符集设置 ·HTMLASCII字符集 ·JS混淆/加密 ·PNG/JPEG图片压缩 ·HTML拾色器 ·JSON格式化工具 ·随机数生成器 最新更新 · CSSminmax()函数 · CSSrepeat()函数 · JavaScript判断... · 如何判断JavaSc... · JavaScriptNumb... · JavaScriptNumb... · JavaScriptNumb... 站点信息 · 意见反馈 · 免责声明 · 关于我们 · 文章归档 关注微信 Copyright©2013-2022菜鸟教程  runoob.comAllRightsReserved.备案号:闽ICP备15012807号-1 微信关注



請為這篇文章評分?