zoukankan      html  css  js  c++  java
  • 干货----001----什么是正则表达式?

    什么是正则表达式?

    在编写处理字符串的程序或网页时,经常会有查找符合某些复杂规则的字符串的需要。正则表达式就是用于描述这些规则的语法,正则表达式对于一个程序员来讲是至关重要的一个知识点,所以学好正则是每一个程序员必须具备的。正则表达式不能独立使用,它只是一种用来定义字符串的规则模式,必须在相应的正则表达式函数中应用,才能实现对字符串的匹配、查找、替换及分割等操作。

    1、正则表达式中包括的元素
    (1)、原子(普通字符:a-z A-Z 0-9 、原子表、 转义字符)
    (2)、元字符 (有特殊功能的字符)
    (3)、模式修正符 (系统内置部分字符 i 、m、S、U…)

    2、正则表达式中的“原子”
    ①a-z A-Z _ 0-9 //最常见的字符
    ②(abc) (skd) //用圆括号包含起来的单元符合
    ③[abcs] [^abd] //用方括号包含的原子表,原子表中的^代表排除或相反内容
    ④转义字符
    d 包含所有数字[0-9]
    D 除所有数字外[^0-9]
    w 包含所有英文字符[a-zA-Z_0-9]
    W 除所有英文字符外[^a-zA-Z_0-9]
    s 包含空白区域如回车、换行、分页等 [f ]
    ……

    3、正则表达式元字符
    * 匹配前一个内容的0次1次或多次
    . 匹配内容的0次1次或多次,但不包含回车换行
    + 匹配前一个内容的1次或多次
    ?匹配前一个内容的0次或1次
    | 选择匹配类似PHP中的| (因为这个运算符合是弱类型导致前面最为整体匹配)
    ^ 匹配字符串首部内容
    $ 匹配字符串尾部内容
     匹配单词边界,边界可以是空格或者特殊符合
    B 匹配除带单词边界意外内容
    {m} 匹配前一个内容的重复次数为M次
    {m,} 匹配前一个内容的重复次数大于等于M次
    {m,n} 匹配前一个内容的重复次数M次到N次
    ( ) 合并整体匹配,并放入内存,可使用1 2…依次获取

    4、模式修正符
    模式修正符是为正则表达式增强和补充的一个功能,使用在正则之外
    常用修正符
    i 正则内容在匹配时候不区分大小写(默认是区分的)
    m 在匹配首内容或者尾内容时候采用多行识别匹配
    S 将转义回车取消是为单行匹配如. 匹配的时候
    x 忽略正则中的空白
    A 强制从头开始匹配
    D 强制$匹配尾部无任何内容
    U 禁止贪婪匹配 只跟踪到最近的一个匹配符并结束,常用在采集程序上的正则表达式

    想我所想,思我所思,乐在其中
  • 相关阅读:
    Office办公软件停止工作解决方案
    Jquery blockUI用法
    IE浏览器对js代码的高要求
    IIS中应用程序切换物理路径遇到的问题
    using关键字
    剑指offer-面试题23-链表中环的入口节点-双指针
    剑指offer-面试题22-链表中倒数第k个节点-双指针
    剑指offer-面试题21-调整数组顺序使奇数位于偶数前面-双指针
    剑指offer-面试题20-表示数值的字符串-字符串
    剑指offer-面试题19-正则表达式匹配-字符串
  • 原文地址:https://www.cnblogs.com/ONEPIECE-ZY/p/4909635.html
Copyright © 2011-2022 走看看