#!/usr/bin/env python
# -*- coding:utf-8 -*-
import re
print(re.findall('alex','yyyyabbblalexrrreooox')) # ”.“ 通配符 匹配除开”\“以外的其他字符
print(re.findall('al.x','yyyyaalqxbbblalexrrreooox')) #”^“ 在启始位置匹配:
print(re.findall('^al','alyyyyaalqxbbblalexrrreooox')) #”$“ 在结束位置匹配:
print(re.findall('oo.$','alyyyyaalqxbbblalexrrreooox')) #”*“ 表示重复 在出现的位置表示对"前一个"字符可以匹配0到多个字符:
print(re.findall('al.*a','alyyyyaalqxbbblalexrrreooox')) #”+“ 表示重复 在出现的位置表示对"前一个"字符可以匹配1到多个字符:
print(re.findall('al.+x','alyyyyaalqxbbblalexrrreooox')) #”?“ 表示重复 在出现的位置表示对"前一个"字符可以匹配0到1个字符:
print(re.findall('al.?x','alyyyyaalqxbbblalexrrreooox')) #”{}“ 表示重复 在出现的位置表示对"前一个"字符可以匹配指定范围个字符:
print(re.findall('al.{1,3}x','alyyyyaalqxbbblalexrrreooox')) #”[]“ 表示重复 在出现的位置表示可以匹配指定字符出现请 :
print(re.findall('a[a-z]d','acd'))#a开头 中间出现a-z中任意一个字符 d结尾 都可以匹配 例如 "abd','acd'
#在[]中出现的元字符 都没有特殊功效只能匹配成一般字符 除开 ”-“表示范围 "^"表示 非 "\d" 表示 数字
print(re.findall('a[^f]d','acd')) #a开头 中间出现非f d结尾 都可以匹配 例如 "abd','acd'
print(re.findall('a[\d]d','acd')) #a开头 中间出现数字 d结尾 都可以匹配 例如 "a1d','a5d' """
\ 反斜杠后边跟元字符去除特殊功能
反斜杠后边跟普通字符实现特殊功能
\d 匹配十进制数字 相当于[0-9]
\D 匹配任何非数字字符 相当于[^0-9]
\s 匹配任何空白字符 相当于[\t\n\r\f\v]
\S 匹配任何非空白字符 相当于[^\t\n\r\f\v]
\w 匹配任何字母数字字符 相当于[a-zA-Z0-9_]
\W 匹配任何非字母数字字符 相当于[^a-zA-Z0-9_]
\b 匹配一个单词后面的空格 """ #正则表达式的 函数 #match : re.match(pattern,string,flags=0) 只匹配启始位置 并且只匹配一次 找到后退出
r =re.match('com','comwww.runcomoob')
print(r.group())#输出匹配到的字符
print(r.span())#输出匹配到字符的位置信息 启始位置 和终止位置(0,3) #search : 和match的区别是search匹配任意位置 并且只匹配一次找到后退出
rs = re.search('com','www.runcomoob')
print(rs.group())#输出匹配到的字符
print(rs.span())#输出匹配到字符的位置信息 启始位置 和终止位置(7,10) #findall: 和上面两个函数方法的 是查询出所有匹配的字符串
ra = re.findall('com','comwww.runcomoob')
print(ra) #findditer: 匹配方法和 findall一样就是返回值 是返回的一个列表
rr = re.finditer('com','comwww.runcomoob')
for item in rr:
print(item.group())
print(item.span()) #sub 安装匹配的字符串替换内容 参数1-需要匹配的字符串格式 2-替换后内容 3-需要替换的原字符串
rsu= re.sub('g.t','have','Y get A,I got B ,I gut C')#返回替换后的字符串
print(rsu)
rsu1 = re.sub('g.t','have','Y get A,I got B ,I gut C',2)#返回替换后的字符串 指定最大替换次数2
print(rsu1) #subn 安装匹配的字符串替换内容 参数1-需要匹配的字符串格式 2-替换后内容 3-需要替换的原字符串 返回值多了 返回替换成功次数
rn= re.subn('g.t','have','Y get A,I got B ,I gut C')#返回替换后的字符串
print(rn) #splite 按照匹配的格式分拆
rp = re.split('\d+','one1tow2tree3four4')
print(rp) #compile 把正则表达式编译成一个对象 便于多次调用
text = "JGood is a handsome boy, he is cool, clever, and so on..."
regex = re.compile(r'\w*oo\w*')#创建正则表达式对象 regex
print(regex.findall(text)) #查询所有包含'oo'的单词 # r 转意字符
r5=re.search(r'\\com','adddss\com').group() #匹配‘\com'
print(r5) #------正则分组::去已经提取到的数据中在提取指定数据
ors="hasaabc dfuojqw halaabc m098u29341"
ra1 = re.findall('h(\w+)a(ab)c',ors)#默认提取到两个 'halaabc','hasaabc' 在把其中括号括起来的'as','al' 取出来分别和后面'ab'
# 组一个值 [('as','ab'),('al','ab')]
print(ra1) #match 和 search 分组方式一样
origin ="has dfuojqw1m098u29341"
r= re.match("h\w+",origin) #一般正则匹配未分组
r=re.match("h(\w+)",origin)#匹配后分组 显示('as',)
r =re.match("h(?P<name>\w+)",origin)#匹配后分组,并把分组结果保存在字典中 key为name print(r.group())
print(r.groups())
print(r.groupdict()) #splite orr = "hello alex bcd alex lge alex acd 19"
rs = re.split('(alex)',orr,1) #分组后 把匹配值 也显示出来['hello ', 'alex', ' bcd alex lge alex acd 19']
rrs = re.split('alex',orr,1)# 未分组,只才分['hello ', ' bcd alex lge alex acd 19']
print(rrs)
print(rs)

python基础学习1-正则表达式的更多相关文章

  1. python基础学习笔记——正则表达式

    1.什么是正则? 正则就是用一些具有特殊含义的符号组合到一起(称为正则表达式)来描述字符或者字符串的方法.或者说:正则就是用来描述一类事物的规则.(在Python中)它内嵌在Python中,并通过 r ...

  2. Day1 Python基础学习

    一.编程语言分类 1.简介 机器语言:站在计算机的角度,说计算机能听懂的语言,那就是直接用二进制编程,直接操作硬件 汇编语言:站在计算机的角度,简写的英文标识符取代二进制去编写程序,本质仍然是直接操作 ...

  3. 0003.5-20180422-自动化第四章-python基础学习笔记--脚本

    0003.5-20180422-自动化第四章-python基础学习笔记--脚本 1-shopping """ v = [ {"name": " ...

  4. Day1 Python基础学习——概述、基本数据类型、流程控制

    一.Python基础学习 一.编程语言分类 1.简介 机器语言:站在计算机的角度,说计算机能听懂的语言,那就是直接用二进制编程,直接操作硬件 汇编语言:站在计算机的角度,简写的英文标识符取代二进制去编 ...

  5. Python 基础学习 总结篇

    Python 基础学习总结 先附上所有的章节: Python学习(一)安装.环境配置及IDE推荐 Python学习(二)Python 简介 Python学习(三)流程控制 Python学习(四)数据结 ...

  6. (一)python基础学习

    根据廖雪峰老师的python教程写一些学习总结! Python基础学习 1.使用list和tuple (1)list Python内置的一种数据类型是列表:list.list是一种有序的集合,可以随时 ...

  7. python基础学习(起步)

    目录 python基础学习(起步) 变量 常量 变量的内存管理 python垃圾回收机制 变量的其他赋值方式 今日编程小题 本人能力有限,若有偏颇之处请读者大大不吝赐教! 祝大家每天都在成长! pyt ...

  8. python基础之坑爹正则表达式

    python基础之坑爹正则表达式 概述 re模块就是python语言中的正则表达式,拆出来单独写一条blog是因为正则表达式本身就是比较庞大的知识,写具体些让自己以后方便查找. IP: ^(25[0- ...

  9. Python基础学习二

    Python基础学习二 1.编码 utf-8编码:自动将英文保存为1个字符,中文3个字符.ASCll编码被囊括在内. unicode:将所有字符保存为2给字符,容纳了世界上所有的编码. 2.字符串内置 ...

  10. Python基础学习一

    Python基础学习一 1.变量与常量 变量名:大小写英文.数字.下划线的组合,数字不能开头 常量名:习惯上常量用大写字母命名,例如"PI" 2.多行输出 转义符:反斜杠(),如果 ...

随机推荐

  1. 监控SQLServer 数据库表每天的空间变化情况

    阅读完桦仔的<分享一个SQLSERVER脚本(计算数据库中各个表的数据量和每行记录所占用空间)>后,我想使用文中提供的代码做一个统计表每天的新增行数及新增存储空间的功能 实现步骤如下: 1 ...

  2. Python学习---Django关于POST的请求解析源码分析

    当有请求到来之后,先判断请求头content_type是不是[application/x-www-form-urlencoded] --> 如果是则将请求数据赋值给request.body然后解 ...

  3. tomcat7换端口号调试

    1.C:\tomcat\conf\server.xml中修改端口号 2.C:\tomcat\bin\startup.bat批处理文件启动tomcat 3.用ctrl+c结束批处理文件 4.调试结束

  4. Visual Studio 2013 Web开发新特性

    微软正式发布Visual Studio 2013 RTM版,微软还发布了Visual Studio 2013的最终版本..NET 4.5.1以及Team Foundation Server 2013. ...

  5. Alpha 冲刺报告(7/10)

    Alpha 冲刺报告(7/10) 队名:洛基小队 峻雄(组长) 已完成:参考已有资源设计角色属性 明日计划:完善并编码 剩余任务:角色的属性脚本 困难:编码进展缓慢 -------------- 非易 ...

  6. 如何运行vue项目(从gethub上download的开源项目)

    前提:入坑vue.js,从GitHub上download一个vue.js的开源项目,发现不知如何在浏览器运行,通过查阅网上教程,发现网上的很多是教你怎么新建项目,并没有一个是教如何打开已有的项目.自已 ...

  7. 20165318 《Java程序设计》实验一(Java开发环境的熟悉)实验报告

    20165318 <Java程序设计>实验一(Java开发环境的熟悉)实验报告 一.实验报告封面 课程:Java程序设计        班级:1653班        姓名:孙晓暄    ...

  8. [USACO09MAR]Moon Mooing

    嘟嘟嘟 某谷的翻译挺迷的,简单来说就是给一个初值c,然后有两个函数f1 = a1 * x / d1 + b1, f2 = a2 * x / d2 + b2.把c分别带进去,所得的结果也递归带进去,这样 ...

  9. vue2.* 事件 定义方法 执行方法 获取数据 改变数据 执行方法传值 以及事件对象 05

    <template> <div id="app"> <button v-on:click="run1()">执行事件的第一种 ...

  10. 随手练——HDU 5015 矩阵快速幂

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5015 看到这个限时,我就知道这题不简单~~矩阵快速幂,找递推关系 我们假设第一列为: 23 a1 a2 ...