A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© xfbyxq 中级黑马   /  2016-7-15 23:40  /  643 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

bool String.matches(reg)

1:正则表达式(理解)
(1)就是符合一定规则的字符串
(2)常见规则
  A:字符
   x 字符 x。举例:'a'表示字符a
   \\ 反斜线字符。
   \n 新行(换行)符 ('\u000A')
   \r 回车符 ('\u000D')

  B:字符类 [ ]  表示单个字符
   [abc] a、b 或 c(简单类)
   [^abc] 任何字符,除了 a、b 或 c(否定)
   [a-zA-Z] a到 z 或 A到 Z,两头的字母包括在内(范围)
   [0-9] 0到9的字符都包括
file:///C:/Users/sanyi/AppData/Local/YNote/data/971762302@qq.com/fb7dbfd0bf364bbf9cba9474a490a9c2/clipboard.png

  C:预定义字符类(虽然没中括号,但也表示单个字符)
   . 任何字符。我的就是.字符本身,怎么表示呢? \.
   \d 数字:[0-9]
   \D  非数字
   \s  空字符
   \S   非空字符
   \w 单词字符:[a-zA-Z_0-9]
   \W  非单词字符
    在正则表达式里面组成单词的东西必须有这些东西组成

  D:边界匹配器
   ^ 行的开头
   $ 行的结尾
   \b 单词边界
    就是不是单词字符的地方。
    举例:hello world?haha;xixi

  E:Greedy 数量词
   X? X,一次或一次也没有
   X* X,零次或多次
   X+ X,一次或多次
   X{n} X,恰好 n 次
   X{n,} X,至少 n 次
   X{n,m} X,至少 n 次,但是不超过 m 次

  F:叠词正则(就是字符串中出现相同的字符可能是两个也可以是多个)
( . ) -->()表示分组匹配里面写表达式  后面可以跟次数如 (.)\\1
例如里面一个点(点表示任一一个字符)后面\\1  表示前面的.代表的字符在出现一次,1代表第一组

file:///C:/Users/sanyi/AppData/Local/YNote/data/971762302@qq.com/50bf388d2001492e8dbd126172d22047/clipboard.png

(3)常见功能:(分别用的是谁呢?)
  A:判断功能
   String类的public boolean matches(String regex)
  B:分割功能
   String类的public String[] split(String regex)
  C:替换功能
   String类的public String replaceAll(String regex,String replacement)
  D:获取功能
   Pattern和Matcher
    Pattern p = Pattern.compile("a*b");
    Matcher m = p.matcher("aaaaab");

    find():查找存不存在
    group():获取刚才查找过的数据(必须先查找才能调用group获取)

1 个回复

倒序浏览
正在看正则表达式呢
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马