import re
import unicodedata s = "a00xoghasalexjkdfldhfjk"
v = s.find("alex")
print(v) k = ""
# 正则模糊匹配 # print(re.findall("alex", s))
# # .是通配符(除了换行之外)
# print(re.findall("a..x", s))
# # ^ (开头)和 $(结尾)
# print(re.findall("^a..x", s))
# print(re.findall("h..k$", s))
# # * (0-max) ;+(1,max) ; ? (0,1) 贪婪匹配
# b = "ccsrwrfdddddddddddkokosadkfod"
# print(re.findall("d*", b))
# print(re.findall("d+", b))
# print(re.findall("alex*", "asdhfale")) # 0-无穷大个
# print(re.findall("alex+", "asdhfale")) # 1-无穷大
# print(re.findall("alex?", "asdhfalex")) # 0-1个
# print(re.findall("alex?", "asdhfale")) # 0-1个
#
# # {}0-无穷大个 == * ; {1,} == + ; {6} 6次
# # {} 可以带贪婪匹配
# print(re.findall("alex{1,4}", "asdhfalexxx")) # 1-4个
# print(re.findall("alex{6}", "asdhfalexxx")) # 必须是6个
# # ? 惰性匹配
# print(re.findall("alex*?", "asdhfalexxx"))
# print(re.findall("alex+?", "asdhfalexxx"))
#
# # []字符集 中没有特殊符号(除了\-^)
# print(re.findall("www[oldboy baidu]", "wwwbaidu"))
# print(re.findall("x[ys]", "xyyszz"))
# print(re.findall("s[zby]a", "xyyszasya"))
# print(re.findall("s[zb,]a", "xyyszas,a"))
#
# print(re.findall("s[zb,]a", "xyyszas,a"))
# print(re.findall("s[zb*]a", "xyyscas,a"))
#
# # -之间
# print(re.findall("s[a-z]*", "sqaaaaerqwr"))
# print(re.findall("s[a-z]*", "sqaaaaerqwr9")) # [a-z] 之间
#
# print(re.findall("s[0-9]*", "s9qaaaaerqwr9")) # [a-z] 之间
# # ^非
# print(re.findall("s[^a-z]", "sqaaaaerqwr9")) # [a-z] 之间
# # \转义
# print(re.findall("\([^()]*\)", "12*(34*6+2-5*(2-1))"))
# print(re.findall("\([^()]+\)", "12*(34*6+2-5*(2-1))"))
#
# # \d 【0-9】的数值
# print(re.findall("\d+", "12*(34*6+2-5*(2-1))")) # [0-9]
# print(re.findall("\D+", "12*(34*6+2-5*(2-1))")) # [^0-9]
# print(re.findall("\s+", "hello world"), "ssss") # \t\n\r\f\v 任何空白符
# print(re.findall("\S+", "hello world")) # [^\t\n\r\f\v]
# print(re.findall("\w+", "hello world")) # [0-9a-zA-Z_]
# print(re.findall("\W", "hello world")) # [^0-9a-zA-Z_]
# print(re.findall("\b", "hello world")) # 空格,&,#
#
# print(re.findall(r"I\b", "hello I am world")) #
# print(re.findall("I\\b", "hello I am world")) #
# # print(re.findall("c\\\f", r"abcde\fgh"))
# # | 或
# print(re.findall("gh|f", "abcde|fgh"))
# # () 分组
# print(re.findall("(abf)*", r"abfabfabfh"))
#
# print(re.findall("(?P<name>\w+)", r"abfabfabfh"))
#
# # search 找到第一个就返回一个对象(需要用group取出),,findall找到所有满足的结果放入列表
#
# print(re.search("\d+","23414afdfasf324fa"))
# print(re.search("\d+","23414afdfasf324fa").group())
# # 分组命名
# print(re.search("(?P<name>[a-z]+)(?P<age>\d+)","23414alex324fa").group("name","age"))
#
# # match 成功返回对象,失败啥也不返回
# print(re.match("\d+", "24dsd143f"))
#
# # split 分割
# print(re.split(" ", "hello abc asf"))
# print(re.split("[ |]", "hello abc|asf"))
# print(re.split("[ab]", "hebllo abc|asf"))
# # ["he","llo abc|asf"]->["he",“llo ","bc|asf"]->
# # ["he","llo "," ","c|asf"]->["he","llo "," ","c|","sf"],
# print(re.split("[ab]", "abc"))
# # 替换
# print(re.sub("\d+","A","dsfaf123aasf42112dfa"))
#
# print(re.subn("\d+","A","dsfaf123aasf42112dfa"))
#
# # 规则,书写规则
# com = re.compile("\d+")
# str1 = "qfaqs234rer1344"
# print(com.findall(str1))
#
# com = re.compile("\d")
# print(com.findall(str1))
# # 迭代器
# ite = com.finditer(str1)
# # next(ite)
# print(ite)
# # ?: 去除优先级
# print(re.findall("www\.(baidu|163)\.com","www.163.com")) # 163
# print(re.findall("www\.(?:baidu|163)\.com","www.163.com")) # www.163.com
# print(re.search("abc|bcd", "abc"))  # search
# print(re.search("a(bc)|bcd", "abc").group())
# "\(9[^()]+\)" print(re.findall("(abc)+", "abcabcabc")) # 给整体添加匹配
print(re.findall("abc+", "abcccabcabcfadfabc")) # ?:去除优先级,给c添加重复匹配
 

6.re正则表达式的更多相关文章

  1. JS正则表达式常用总结

    正则表达式的创建 JS正则表达式的创建有两种方式: new RegExp() 和 直接字面量. //使用RegExp对象创建 var regObj = new RegExp("(^\\s+) ...

  2. Python高手之路【五】python基础之正则表达式

    下图列出了Python支持的正则表达式元字符和语法: 字符点:匹配任意一个字符 import re st = 'python' result = re.findall('p.t',st) print( ...

  3. C# 正则表达式大全

    文章导读 正则表达式的本质是使用一系列特殊字符模式,来表示某一类字符串.正则表达式无疑是处理文本最有力的工具,而.NET提供的Regex类实现了验证正则表达式的方法.Regex 类表示不可变(只读)的 ...

  4. C#基础篇 - 正则表达式入门

    1.基本概念 正则表达式(Regular Expression)就是用事先定义好的一些特定字符(元字符)或普通字符.及这些字符的组合,组成一个“规则字符串”,这个“规则字符串”用来判断我们给定的字符串 ...

  5. JavaScript正则表达式,你真的知道?

    一.前言 粗浅的编写正则表达式,是造成性能瓶颈的主要原因.如下: var reg1 = /(A+A+)+B/; var reg2 = /AA+B/; 上述两个正则表达式,匹配效果是一样的,但是,效率就 ...

  6. Python 正则表达式入门(中级篇)

    Python 正则表达式入门(中级篇) 初级篇链接:http://www.cnblogs.com/chuxiuhong/p/5885073.html 上一篇我们说在这一篇里,我们会介绍子表达式,向前向 ...

  7. 【JS基础】正则表达式

    正则表达式的() [] {}有不同的意思. () 是为了提取匹配的字符串.表达式中有几个()就有几个相应的匹配字符串. (\s*)表示连续空格的字符串. []是定义匹配的字符范围.比如 [a-zA-Z ...

  8. JavaScript 正则表达式语法

    定义 JavaScript定义正则表达式有两种方法. 1.RegExp构造函数 var pattern = new RegExp("[bc]at","i"); ...

  9. [jquery]jquery正则表达式验证(手机号、身份证号、中文名称)

    数字判断方法:isNaN()函数 test()方法 判断字符串中是否匹配到正则表达式内容,返回的是boolean值 ( true / false ) // 验证中文名称 function isChin ...

  10. JS中给正则表达式加变量

    前不久同事询问我js里面怎么给正则中添加变量的问题,遂写篇博客记录下.   一.字面量 其实当我们定义一个字符串,一个数组,一个对象等等的时候,我们习惯用字面量来定义,例如: var s = &quo ...

随机推荐

  1. 从git上pull下的代码,执行时提示:ModuleNotFoundError: No module named '......',解决方法如下:

    方法一: 如果没有安装,如下: 1.PyCharm : file-> setting->Project interpreter–>package2.右侧有个+ 点击3.进入后 搜索p ...

  2. LeetCode.997-找到镇法官(Find the Town Judge)

    这是悦乐书的第373次更新,第400篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第234题(顺位题号是997).在一个城镇,有N个人从1到N标记.有传言说其中一个人是秘 ...

  3. DNS的解析流程

    一.简单理解 DNS服务器里存着一张表,表中放着域名和IP地址,域名和IP地址以映射关系保存,即一对一 浏览器访问某个域名,实际上是访问它的ip地址 所以浏览器需要知道域名对应的ip地址,由此产生dn ...

  4. SVM的推导和理解

    主要记录了SVM思想的理解,关键环节的推导过程,主要是作为准备面试的需要. 1.准备知识-点到直线距离 点\(x_0\)到超平面(直线)\(w^Tx+b=0\)的距离,可通过如下公式计算: \[ d ...

  5. Python pymysql对数据库的基础操作

    示例数据库名demo,表名info select * from info; 查看该表数据 +----+-------+--------+-----+---------------------+---- ...

  6. 记录一些Xampp的使用过程和遇到的问题

    1.Xmapp需要安装在C盘的Xampp目录,否则很容易出错,一定要在C:/xampp,这样Apache和MySQL才能正常启动,和错误提示的端口冲突或者路径错误无关. 2.Xmapp尽量选择低版本的 ...

  7. java中的小知识点

    1.数据类型的相关知识点 1.1.java内置封装类的转换 java中内置的封装类Byte.Integer.Float.Double和Long都可以转换成double类型的数值:因为这些封装好的类中都 ...

  8. 多次NameNode执行format后DataNode启动不了解决方案

    1.问题 执行start-dfs.sh后在进程中查看jps,发现NameNode启动,但DataNode没有 2.原因 在失败的.log文件中看到datanode的clusterID 和 nameno ...

  9. map member functions

    http://www.cplusplus.com 搜了才发现map的成员函数这么多orz,跟着cplusplus按字典序走一遍叭(顺序有微调orz <1>  map::at (c++11) ...

  10. dict 小习题

    1.请将列表中的每个元素通过 "" 链接起来. users = ['大黑哥','龚明阳',666,'渣渣辉'] a='' for i in users: i=str(i) a=a+ ...