码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 正则系列之量词(Quantifiers)


    目录

    • 1、`x*`
    • 2、`x+`
    • 3、`x?`
    • 4、`x{n}`
    • 5、`x{n,}`
    • 6、`x{n,m}`
    • 7、`x*?` `x+?` `x??` `x{n}?` `x{n,}?` `x{n,m}?`
    • 后记


    量词表示要匹配的字符或表达式的数量。

    1、x*

    将前面的项“x”匹配 0 次或更多次。

    let reg = /bo*/g;
    let str = "A ghost booooed";
    str.match(reg); // ['boooo']
    str = "A bird warbled";
    str.match(reg); // ['b', 'b']
    str = "A goat grunted";
    str.match(reg); // null
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    2、x+

    将前一项“x”匹配 1 次或更多次,等价于{1,}。

    let reg = /bo+/g;
    let str = "A ghost booooed";
    str.match(reg); // ['boooo']
    str = "A bird warbled";
    str.match(reg); // null
    str = "A goat grunted";
    str.match(reg); // null
    reg = /a+/g;
    str = "caaaaaaandy";
    str.match(reg); // ['aaaaaaa']
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    3、x?

    将前面的项“x”匹配 0 或 1 次。

    如果在任何量词*、+、?或{}之后使用?,则使量词是非贪婪的 (匹配最小次数),而不是默认的贪婪的 (匹配最大次数)。

    let reg = /bo?/g;
    let str = "A ghost booooed";
    str.match(reg); // ['bo']
    str = "A bird warbled";
    str.match(reg); // ['b', 'b']
    str = "A goat grunted";
    str.match(reg); // null
    reg = /bo??/g;
    str = "A ghost booooed";
    str.match(reg); // ['b']
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    4、x{n}

    其中“n”是一个正整数,与前一项“x”的 n 次匹配。

    let reg = /a{2}/g;
    let str = "candy";
    str.match(reg); // null
    str = "caandy";
    str.match(reg); // ['aa']
    str = "caaandy";
    str.match(reg); // ['aa']
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    5、x{n,}

    其中,“n”是一个正整数,与前一项“x”至少匹配“n”次。

    let reg = /a{2,}/g;
    let str = "caaandy";
    str.match(reg); // ['aaa']
    
    • 1
    • 2
    • 3

    6、x{n,m}

    其中n为0或正整数,m为正整数,且m > n,前一项x至少匹配n次且最多匹配m次。

    let reg = /a{2,4}/g;
    let str = "caaaaaaaaaaandy";
    str.match(reg); // ['aaaa', 'aaaa', 'aaa']
    
    • 1
    • 2
    • 3

    7、x*? x+? x?? x{n}? x{n,}? x{n,m}?

    默认情况下,像*和+这样的量词是“贪婪的”,这意味着它们试图匹配尽可能多的字符串。量词后面的字符?使量词“非贪婪”:这意味着一旦找到匹配,它就会停止。

    let reg = /a{2,4}?/g;
    let str = "caaaaaaaaaaandy";
    str.match(reg); //  ['aa', 'aa', 'aa', 'aa', 'aa']
    
    • 1
    • 2
    • 3

    后记

    如果你感觉文章不咋地//(ㄒoㄒ)//,就在评论处留言,作者继续改进;o_O???
    如果你觉得该文章有一点点用处,可以给作者点个赞;\\*^o^*//
    如果你想要和作者一起进步,可以微信扫描二维码,关注前端老L;~~~///(^v^)\\\~~~
    谢谢各位读者们啦(^_^)∠※!!!

    在这里插入图片描述

  • 相关阅读:
    chatgpt赋能python:Python数值计算指南:为什么它是一种强大的工具
    【UE5 C++基础 04】UHT基础
    centos中nacos设置开机自启动
    民安智库(第三方满意度调研公司)如何做物业满意度调查
    java实现TCP通信(socket)服务端-客户端
    吴恩达深度学习笔记:深度学习引言1.1-1.5
    学习.NET验证模块FluentValidation的基本用法
    【JavaSE】面向对象三大特性之多态
    MongoDB分页排序问题,本页排序与结果集排序
    4.【Sharding-JDBC】分库分表
  • 原文地址:https://blog.csdn.net/weixin_62277266/article/details/125557986
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号