python 正则 括号_js正则匹配0个或多个空格

python 正则 括号_js正则匹配0个或多个空格\d匹配一个数字\w匹配一个字母或数字.匹配任意字符*表示任意个字符(包括0个),+表示至少一个字符?表示0个或1个字符^表示行的开头$表示行的结束\s匹配一个空格(也包括Tab等空白符)\s+表示至少有一个空格|A|B可以匹配A或B,所以(P|p)ython可以匹配’Pyth…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

\d 匹配一个数字

\w 匹配一个字母或数字

. 匹配任意字符

* 表示任意个字符(包括0个),

+ 表示至少一个字符

? 表示0个或1个字符

^ 表示行的开头

$ 表示行的结束

\s 匹配一个空格(也包括Tab等空白符)

\s+ 表示至少有一个空格

| A|B可以匹配A或B,所以(P|p)ython可以匹配’Python’或者’python’。

{n} 表示n个字符

{n,m} 表示n-m个字符

– 是特殊字符,在正则表达式中,要用’\’转义

[a-zA-Z\_][0-9a-zA-Z\_]{0, 19}更精确地限制了变量的长度是1-20个字符(前面1个字符+后面最多19个字符)。

s = ‘ABC\\-001′ #Python的字符串#对应的正则表达式字符串变成:#’ABC\-001’

使用Python的r前缀,就不用考虑转义的问题了:

s = r’ABC\-001′ #Python的字符串#对应的正则表达式字符串不变:#’ABC\-001′

re.match(r’^\d{3}\-\d{3,8}$’, ‘010-12345’)

切分字符串

用正则表达式切分字符串比用固定的字符更灵活,请看正常的切分代码:

>>> ‘a b c’.split(‘ ‘)

[‘a’, ‘b’, ”, ”, ‘c’]

识别连续的空格,用正则表达式:

>>> re.split(r’\s+’, ‘a b c’)

[‘a’, ‘b’, ‘c’]

无论多少个空格都可以正常分割:

>>> re.split(r'[\s\,]+’, ‘a,b, c d’)

[‘a’, ‘b’, ‘c’, ‘d’]

再加入;试试:

>>> re.split(r'[\s\,\;]+’, ‘a,b;; c d’)

[‘a’, ‘b’, ‘c’, ‘d’]

提取子串:

>>> m = re.match(r’^(\d{3})-(\d{3,8})$’, ‘010-12345’)>>>m<_sre.sre_match object span=”(0,” match=”010-12345″>

>>>m.group(0)’010-12345′

>>> m.group(1)’010′

>>> m.group(2)’12345′

注意到group(0)永远是原始字符串,group(1)、group(2)……表示第1、2、……个子串。

匹配时间:

>>> t = ’19:05:30′

>>> m = re.match(r’^(0[0-9]|1[0-9]|2[0-3]|[0-9])\:(0[0-9]|1[0-9]|2[0-9]|3[0-9]|4[0-9]|5[0-9]|[0-9])\:(0[0-9]|1[0-9]|2[0-9]|3[0-9]|4[0-9]|5[0-9]|[0-9])$’, t)>>>m.groups()

(’19’, ’05’, ’30’)

编译

在Python中使用正则表达式时,re模块内部会干两件事情:

编译正则表达式,如果正则表达式的字符串本身不合法,会报错;

用编译后的正则表达式去匹配字符串。

如果一个正则表达式要重复使用几千次,出于效率的考虑,我们可以预编译该正则表达式,接下来重复使用时就不需要编译这个步骤了,直接匹配:

>>> importre#编译:

>>> re_telephone = re.compile(r’^(\d{3})-(\d{3,8})$’)#使用:

>>> re_telephone.match(‘010-12345’).groups()

(‘010’, ‘12345’)>>> re_telephone.match(‘010-8086’).groups()

(‘010’, ‘8086’)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/234430.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • TFIDF算法Java实现

    TFIDF算法Java实现一 算法简介 TF IDF termfrequenc inversedocum 是一种用于信息检索与数据挖掘中常用的加权技术 TF IDF 的概念被公认为信息检索中最重要的发明 在搜索 文献分类和其他相关领域有着广泛的应用 其具体应用包括关键词提取 文本相似度 自动摘要 TF IDF 的主要思想是如果某个词在一篇文章中出现的频率 TF 很高 而且在语料库中的其他文章中

    2025年11月4日
    2
  • IDEA汉化教程(一分钟即可)「建议收藏」

    IDEA汉化教程(一分钟即可)「建议收藏」Idea汉化教程(简单,一分钟即可)步骤打开idea点击左上角的File,然后点击Settings(如下图)进去后点击Plugins,然后点击Marketplace,然后再搜索框搜索chinese然后搜索出东西,点击下面标注的,点击安装然后下载好后再点击右侧的安装(由于我已经安装了,所以才有中文跟显示以安装)。安装完后重启就可以看到idea被汉化了…

    2022年5月11日
    95
  • python的学生信息管理系统_学员信息管理系统设计

    python的学生信息管理系统_学员信息管理系统设计一.系统需求使用面向对象编程思想完成学员管理系统的开发,具体如下:系统要求:学员数据存储在文件中系统功能:添加学员、删除学员、修改学员信息、查询学员信息、显示所有学员信息、保存学员信息及退出系统等功能。程序文件如下:程序入口文件:main.py学员文件:student.py管理系统⽂文件:managerSystem.pymain.py#1.导入managerSystem模块frommanagerSystemimport*#2.启动学员管理系统if__name__

    2022年9月20日
    3
  • python 爬虫 美女_Python3爬取美女妹子图片

    python 爬虫 美女_Python3爬取美女妹子图片1.效果图先看效果图,哈哈哈,是不是很有学习的欲望了,开干。爬图的数量根据你输入的页数确定,纯洁的我只是适当的爬了几张学习技术。效果图2.爬取妹子图片准备工作Python3.xPycharm等随意一款编辑器os库、requests库、pyquery库2.1安装库2.1.1cmd安装方式打开cmd控制台打开cam控制台在控制台分别输入以下代码:pipinstallrequestspip…

    2025年11月17日
    3
  • 大一c语言图书管理系统_基于java的图书管理系统

    大一c语言图书管理系统_基于java的图书管理系统C课程设计——图书管理系统1、题目意义图书馆,作为文献的聚集地和展示平台,常常扮演着引领文化前进的角色,是每个大学不可或缺的基础设施,而图书管理系统则是一个图书馆能够正常运转的关键。本次课程设计使用C语言制作程序来实现图书的登记,删除,查询,浏览以及读者的借阅,还书,会员登录,修改密码等功能。程序中涉及到数据链表和文件指针的操作,包括结构体数据定义,使用及文件的读写,定位,修改等。2、设计思…

    2022年10月11日
    1
  • php开发中处理emoji表情和颜文字的兼容问题

    php开发中处理emoji表情和颜文字的兼容问题

    2021年11月3日
    67

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号