zoukankan      html  css  js  c++  java
  • 正则总结

    1、元字符
    [拥有特殊含义的元字符]
    d -> 匹配一个0-9的数字,相当于[0-9],和它相反的是D ->匹配一个除了0-9的任意字符
    w -> 匹配一个0-9、a-z、A-Z、_的数字或字符,相当于[0-9a-zA-Z_]
    s -> 匹配一个空白字符(空格、制表符...)
     -> 匹配一个单词的边界
    -> 匹配一个制表符
    -> 匹配一个换行
    . -> 匹配一个除了 以外的任意字符
    ^ -> 以某一个元字符开头
    $ -> 以某一个元字符结尾
    -> 转移字符
    x|y -> x或者y的一个
    [xyz] -> x、y、z中的任意一个
    [^xyz] -> 除了xyz中的任意一个字符
    [a-z] -> 匹配a-z中的任意一个字符
    [^a-z] -> 匹配除了a-z中的任意一个字符
    () -> 正则中的分组

    注意:
    1)关于[]
    a、[+] ->中括号中出现的所有字符都代表的是本身的意思
    b、[12-65] ->这个不是12-65而是1/2-6/5三者中的一个

    2)关于()
    a、分组的作用是改变默认的优先级,例如:/^18|19$/,181、189、119、819、1819...都符合,而不是我们认为的18或19,但是改成/^(18|19)$/就是单纯的18或19了
    b、可以在捕获大正则匹配的内容同时,把分组匹配的内容也进行捕获->分组捕获
    c、分组引用,例如:/^(d)(w)21$/,这里的2是和第二个分组出现一模样的内容,1是和第一个分组出现一模一样的内容,例如:"0aa0"就符合了

    [代表数量的量词元字符]
    * -> 0到多个
    + -> 1到多个
    ? -> 0到1个
    {n} -> 出现n次
    {n,} -> 出现n到多次
    {n,m} -> 出现n到m次

    注意:
    1)关于?的几种情况
    a、放在非量词元字符后面,代表出现0-1次
    b、放在量词元字符后面,代表取消捕获时候的贪婪性,例如:reg=/d+/; reg.exec("2015") -> "2015" 但是如果正则这样写 reg=/d+?/; reg.exec("2015") -> "2"
    c、在分组开头加?:,代表当前的分组只是匹配不进行捕获,例如:/^(?:d+)$/
    d、在分组开头加?=,正向预查,例如:/^zhufeng(?=1|2)$/ 只有"hanjiajun1"和"hanjiajun"才符合
    e、在分组开头加?!,负向预查,例如:/^zhufeng(?!1|2)$/ 除了"hanjiajun1"和"hanjiajun2"不符合,其他的只要是"zhufeng(任何的东西)"都符合

    [代表本身意思的元字符]
    除了以上的,在字面量方式中,我们出现的其他任意字符代表的都是自己本身的意思
    var num=12;
    var reg=/^w"+num+"$/; ->这里"+num+"不是把变量的值拼接,而这里的不管是"还是+都是元字符
    ->对于需要拼接字符串和变量的方式我们只能使用实例方式创建正则

    2、修饰符
    i -> ignoreCase 忽略字母的大小写
    g -> global 全局匹配 (加上g可以解决正则捕获时候的懒惰性)
    m -> multiline 多行匹配

    3、项目中常用的正则
    1)有效数字的
    var reg=/^[+-]?(d|([1-9]d+))(.d+)?$/;

    2)邮箱的
    var reg = /^w+((-w+)|(.w+))*@[A-Za-z0-9]+((.|-)[A-Za-z0-9]+)*.[A-Za-z0-9]+$/;

    3)电话的
    var reg = /^1d{10}$/;

    4)年龄在18-65之间的
    var reg = /^((18|19)|([2-5]d)|(6[0-5]))$/;

    5)中文姓名
    var reg = /^[u4e00-u9fa5]{2,4}$/;

    6)身份证
    var reg = /^(d{6})(d{4})(d{2})(d{2})(?:d{2})(d)(?:d|X)$/;
    //-> 130828(省市县) 1990(年) 12(月) 04(日) 06 1(奇数是男偶数是女) 7(数字或者X)

    4、正则的匹配
    reg.test([string]) ->true就是匹配成功 false->匹配不成功

    5、正则的捕获
    1)reg.exec([string])
    -> 首先去匹配,匹配成功在捕获,返回的是一个数组; 如果匹配不成功返回的是null;
    -> 正则的捕获即懒惰又贪婪
    -> 解决懒惰性 在正则的末尾增加全局修饰符g
    -> 解决贪婪性 在量词后面加?

    6、正则实战应用之-replace
    1)获取一个字符串中出现次数最多的字符和对应的次数,例如:var str = "zhufengpeixun2015yangfanqihang";问哪几个字符出现的次数最多,一共有多少次?

    2)千分符

    3)模板引擎绑定数据实现的原理
    var ary = ["天才", "26", "china", "javascript"];
    var str = "my name is {0},my age is {1},i com from {2},i can do {3}~~";
    ->"my name is 天才,my age is 26,i com from china,i can do javascript~~";

    4)单词首字母大写
    var str="my name is zhou xiao tian,my age is twenty five years old~~";
    ->把所有单词的首字母大写

    5)格式化时间
    var str="2015-5-3 12:9:13";
    ->"2015年05月03日 12时09分13秒"

    6)queryURLParameter 获取地址栏中的参数
    http://kbs.sports.qq.com/kbsweb/game.htm?mid=1467588&age=18
    URL问号传参 -> mid=xxxx 就是我们传递过来的内容,我们需要获取mid,并且通过mid区分展示不同的内容
    ->{mid:"1467588",age:18}

    7)在我们的utils.js这个DOM库中很多方法的编写中都使用了部分正则,大家自己回去看一下,尤其是getElementsByClass这个方法

  • 相关阅读:
    异步与回调的设计哲学
    CTF之PHP黑魔法总结
    图片隐写分离
    phpMyadmin各版本漏洞
    python 多线程
    order by name 注入
    Python lambda
    Python os.popen() 方法
    你和大牛差了啥
    Error: failure: repodata/repomd.xml from fedora: [Errno 256] No more mirrors to try.
  • 原文地址:https://www.cnblogs.com/han6054/p/5542692.html
Copyright © 2011-2022 走看看