• Java正则表达式


    java中提供了对正则表达式的支持。
    有的时候,恰当地使用正则,可以让我们的工作事半功倍!
    如下代码用来检验一个四则运算式中数据项的数目,请填写划线部分缺少的代码。
    注意:只填写缺少代码,不要写任何多余内容,例如,已有的双引号。
    public class A
    {
    public static int f(String s)
    {
    return s.split("________________").length;
    }

    public static void main(String[] args)
    {
    System.out.println(f("12+35*5-2*18/9-3")); //7
    System.out.println(f("354*12+3-14/7*6")); //6
    }

    }

    参考答案:

     return s.split("\p{Punct}").length;//以运算符号分割  

    正则表达式的构造摘要

     

    构造匹配
     
    字符
    x 字符 x
    \ 反斜线字符
    n 带有八进制值 0 的字符 n (0 <= n <= 7)
    nn 带有八进制值 0 的字符 nn (0 <= n <= 7)
    mnn 带有八进制值 0 的字符 mnn(0 <= m <= 3、0 <= n <= 7)
    xhh 带有十六进制值 0x 的字符 hh
    uhhhh 带有十六进制值 0x 的字符 hhhh
    制表符 ('u0009')
    新行(换行)符 ('u000A')
    回车符 ('u000D')
    f 换页符 ('u000C')
    a 报警 (bell) 符 ('u0007')
    e 转义符 ('u001B')
    cx 对应于 x 的控制符
     
    字符类
    [abc] ab 或 c(简单类)
    [^abc] 任何字符,除了 ab 或 c(否定)
    [a-zA-Z] a 到 z 或 A 到 Z,两头的字母包括在内(范围)
    [a-d[m-p]] a 到 d 或 m 到 p[a-dm-p](并集)
    [a-z&&[def]] de 或 f(交集)
    [a-z&&[^bc]] a 到 z,除了 b 和 c[ad-z](减去)
    [a-z&&[^m-p]] a 到 z,而非 m 到 p[a-lq-z](减去)
     
    预定义字符类
    . 任何字符(与行结束符可能匹配也可能不匹配)
    d 数字:[0-9]
    D 非数字: [^0-9]
    s 空白字符:[ x0Bf ]
    S 非空白字符:[^s]
    w 单词字符:[a-zA-Z_0-9]
    W 非单词字符:[^w]
     
    POSIX 字符类(仅 US-ASCII)
    p{Lower} 小写字母字符:[a-z]
    p{Upper} 大写字母字符:[A-Z]
    p{ASCII} 所有 ASCII:[x00-x7F]
    p{Alpha} 字母字符:[p{Lower}p{Upper}]
    p{Digit} 十进制数字:[0-9]
    p{Alnum} 字母数字字符:[p{Alpha}p{Digit}]
    p{Punct} 标点符号:!"#$%&'()*+,-./:;<=>?@[]^_`{|}~
  • 相关阅读:
    linux基础学习-8.1-无法远程连接服务器常见原因
    schema约束文档 根元素的写法
    用双重for循环生成九九乘法表
    Random类、String类的一些常用方法
    Random()方法结合Scanner类实现猜数游戏
    使用System类和Date类来计算自己从出生到现在度过了多少时间
    获取map集合中键和值的三种方式
    斗地主实现洗牌发牌功能
    集合框架<一>
    动手动脑2
  • 原文地址:https://www.cnblogs.com/upstart/p/6480314.html
Copyright © 2020-2023  润新知