一, 转译符

  1.python 中的转译符

    正则表达式中的内容在Python中就是字符串

    ' \n ' : \ 转移符赋予了这个n一个特殊意义,表示一个换行符

    ' \ \ n' :  \ \  表示取消了\的转译

    r  表示取消本字符串的所有转译

    在正则表达式中: '\\n'-->'\n',但是在pycharm中 \n为换行符,则需要转译 '\\n',与之匹配

      的应为 : '\\\\n'-->'\\n '

    在Python中 : r '\\n'-->r '\n'

   

   2. 正则表达式中的转义

    ' \( ' 表示匹配小括号 ; [() + * ? / $ .] 在字符组中一些特殊的字符会现原形.

    [ - ] 只写在字符组的首位的时候表示普通的 减号 / 负号写在其他位置表示范围

      如果就是想匹配减号 [1\-9]

二, re 模块

  操作匹配的字符串

  方法: findall  search  math  替换  sub subn  切割  compile  finditer

 1. 查找 

  findall : re.findall('正则表达式','字符串') 

ret = re.findall('\d+','123qwer123df')
print(ret)  #参数  返回值类型:列表  返回值个数:1  返回值内容:所有匹配的项若没有
          匹配到就是空列表 []

  

  search : re.search('正则表达式','字符串') 

ret = re.search('\d+','123qwer123df')
print(ret) #参数 返回值类型: 正则匹配结果的对象 返回值个数 : 1
如果匹配上就返回对象,没匹配上返回None
print(ret.group()) #返回的对象通过group来获取匹配到的第一个结果 

  match : re.match('正则表达式','字符串') 

ret = re.match('\d+','%^123qwer123df')
print(ret)
#结果 : None #只从头开始匹配,相当于在正则表达式前添加一个 ^

 2. 替换( replace)

  sub

ret = re.sub('\d+','H','123qwedf',1)  #把'\d+'替换成'H',指定替换一次(不指定次数全替换)
print(ret)

  subn

ret = re.subn('\d+','H','123qwedf',1)
print(ret)
#结果 ('Hqwerdf' , 1) 给出替换结果和替换的次数

 3. 切割 (split) 

ret = re.split('\d+','123qwerdf')
print(ret) #按数字切割

 4. compile  (提高时间效率)

ret = re.compile('-0\.\d+|-[1-9]\d(\.\d+)?')   #可以重复被利用 ,在多
次使用某一个相同的正则表达式的时候,compile会提高
程序的效率. re = ret.search('qwe-20df-3')
print(re.group())
#结果 -20

  5. finditer  (提高空间效率)  

ret = re.finditer('\d','123qwerdf')    #拿到一个生成器
for i in ret #拿到正则表达式对象
print(i.group())

 6. 分组优先显示

  findall 

ret =  re.findall('www.(baidu|goole).com,'www.baidu.com')
print(ret)
#结果 [] findall 会优先显示分组中的 baidu|goole 匹配内容,要想取消分
组优先,(?:正则表达式)

  split

ret = re.split('(\d+)','qwe12d34f')
print(ret) #遇到分组会保留 被切掉的内容
#结果 ['qwe','12','d','34','f']

  search

re.search('\d+(.\d+)(.\d+)?','1.2.3-2*(60+(-40.35/5))')
print(ret.group())#全部输出/即是print(ret.group(0))
print(ret.group(1))# .2 优先输出(.\d+) print(ret.group(2))# .3 
  #如果search中有分组,通过group(n)就能够拿到group中的匹配的内容

 7. 分组命名  

   (?P<name>正则表达式)  表示给分组起名字 ;  (?P=name) 表示使用分组

  当匹配的内容和 另一部分必须一样是可以使用分组命名

  前后组名必须一样才能匹配成功

  必须先定义分组才能使用分组

   

 索引方法使用分组

  \1 表示使用第一组,匹配到的内容必须和第一个组中的内容完全相同

  

三, random模块

 随机: 在某个范围内取到每一个值的概率是相同的

 1. 随机小数

  random.random()  0-1之间的随机小数

  random.uniform(1,9)  任意范围内的小数

 

 2. 随机抽取

  num = [1,2,3,'qwe',('hehe','haha')]

  random.choice(num)  随机抽取列表中一个值

  random.sample(num,2) 随机抽取列表中2(多个值)值

 

 3. 随机整数

  random.randint(1,8)  [1,8] 包含8在内的范围内随机取整数

  random.randrange(1,8)  [1,8) 不包含8在内的范围内随机取整数

  random.randrange(1,10,2) [1,8) 不包含8在内的范围内随机取奇数整数

 4. 打乱顺序

  num = [1,2,3,'qwe',('hehe','haha')]

  random.shuffle(num)  在原列表基础上打乱顺序

  

转译符,re模块,random模块的更多相关文章

  1. python常用模块——random模块

    参考博客:http://www.360doc.com/content/14/0430/11/16044571_373443266.shtml 今天突然想起python该怎么生成随机数?查了一下,贴出实 ...

  2. Python进阶(十)----软件开发规范, time模块, datatime模块,random模块,collection模块(python额外数据类型)

    Python进阶(十)----软件开发规范, time模块, datatime模块,random模块,collection模块(python额外数据类型) 一丶软件开发规范 六个目录: #### 对某 ...

  3. Python模块01/自定义模块/time模块/datetime模块/random模块

    Python模块01/自定义模块/time模块/datetime模块/random模块 内容大纲 1.自定义模块 2.time模块 3.datetime模块 4.random模块 1.自定义模块 1. ...

  4. python-Day5-深入正则表达式--冒泡排序-时间复杂度 --常用模块学习:自定义模块--random模块:随机验证码--time & datetime模块

    正则表达式   语法:             mport re #导入模块名 p = re.compile("^[0-9]") #生成要匹配的正则对象 , ^代表从开头匹配,[0 ...

  5. Python:time模块/random模块/os模块/sys模块

    time 模块 #常用方法 1.time.sleep(secs) (线程)推迟指定的时间运行.单位为秒. 2.time.time() 获取当前时间戳 python中时间日期格式化符号: %y 两位数的 ...

  6. 4-24日 collections模块 random模块 time模块 sys模块 os模块

    1, collections模块 在内置数据类型(dict.list.set.tuple)的基础上,collections模块还提供了几个额外的数据类型:Counter.deque.defaultdi ...

  7. python 全栈开发,Day27(复习, defaultdict,Counter,时间模块,random模块,sys模块)

    一.复习 看下面一段代码,假如运行结果有问题,那么就需要在每一步计算时,打印一下结果 b = 1 c = 2 d = 3 a = b+c print(a) e = a + d print(e) 执行输 ...

  8. re模块 ,random模块

    # 在python中使用正则表达式 # 转义符 : 在正则中的转义符 \ 在python中的转义符# 正则表达式中的转义 :# '\(' 表示匹配小括号# [()+*?/$.] 在字符组中一些特殊的字 ...

  9. 常用模块(collections模块,时间模块,random模块,os模块,sys模块,序列化模块,re模块,hashlib模块,configparser模块,logging模块)

    认识模块 什么是模块? 常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 但其实import加载的模块分为四个通用类别: 1 使用python编写的 ...

随机推荐

  1. Flask博客类登录注册验证模块代码(十四)

    1 文件系统 blog #博客类 App forms #表单 __init__.py user.py models #模型 __init__.py user.py static #静态文件 templ ...

  2. 从头基于空镜像scratch创建一个新的Docker镜像

    我们在使用Dockerfile构建docker镜像时,一种方式是使用官方预先配置好的容器镜像.优点是我们不用从头开始构建,节省了很多工作量,但付出的代价是需要下载很大的镜像包. 比如我机器上docke ...

  3. userdel

    功能说明:用于删除指定的用户及该用户相关的文件. 参数选项:-f 强制删除用户,即使用户当前已登录.-r 删除用户的同时,删除与用户相关的所有文件. 说明:尽量不要用userdel删除用户,而是采用在 ...

  4. python 用cookie模拟登陆网站

    import re import requests def get_info(url): headers = { "Cookie" :"***************** ...

  5. Android(java)学习笔记11:生产者和消费者之等待唤醒机制

    1. 首先我们根据梳理我们之前Android(java)学习笔记70中,关于生产者和消费者程序思路: 2. 下面我们就要重点介绍这个等待唤醒机制: (1)第一步:还是先通过代码体现出等待唤醒机制 下面 ...

  6. Android(java)学习笔记24:自定义异常类

    1. 自定义异常: 考试成绩必须在0-100之间 很明显java没有对应的异常,需要我们自己来做一个异常 自定义异常 继承自Exception 继承自RuntimeException 下面是一个代码示 ...

  7. html默认样式重置

    几个著名的重置css   goal https://meyerweb.com/eric/tools/css/reset/ 雅虎 https://yuilibrary.com/yui/docs/cssr ...

  8. build.gradle中的dependencies

    demo_myna中的build.gradle中的dependencies是依赖项目.比如之前开发的一个项目A,现在新的项目B要使用项目A的功能,那么把项目A作为类库关联进来,这样b就能直接使用A的功 ...

  9. 如何删除anaconda

    因为实验室电脑之前装tensorflow是用的anaconda装的,导致现在用pip装tensorflow1.0装上了却还是用的annaconda下的tensorflow0.8,所以想删除anacon ...

  10. WPF学习笔记(7):DataGrid中数字自定义格式显示

    DataGrid中数据显示如下图,数据格式比较杂乱.希望达到以下要求:(1)所有数据保留两位小数:(2)超过1000的数字显示千分位:(3)如果数据为0,不显示. 首先想到用StringFormat进 ...