零基础学 Python(2018 版)
尹会生
前游戏公司技术总监,前新浪网技术经理
80146 人已学习
新⼈⾸单¥68
课程目录
已完结/共 72 讲
第一章 :Python介绍和安装 (3讲)
第二章 :Python基础语法 (3讲)
第四章 :条件与循环 (5讲)
第五章 :映射与字典 (2讲)
第六章 :文件和输入输出 (2讲)
第七章 :错误和异常 (1讲)
第九章 :模块 (1讲)
第十章 :语法规范 (1讲)
第十一章 :面向对象编程 (4讲)
第十二章 :多线程编程 (2讲)
第十六章 :综合案例 & 结课测试 (1讲)
特别放送 (1讲)
零基础学 Python(2018 版)
登录|注册
留言
7
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 45 | 正则表达式库函数match与search的区别
00:00 / 00:00
高清
  • 高清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.75x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看
01 | Python语言的特点
02 | Python的发展历史与版本
03 | Python的安装
04 | Python程序的书写规则
05 | 基础数据类型
06 | 变量的定义和常用操作
07 | 序列的概念
08 | 字符串的定义和使用
09 | 字符串的常用操作
10 | 元组的定义和常用操作
11 | 列表的定义和常用操作
12 | 条件语句
13 | for循环
14 | while循环
15 | for循环语句中的if嵌套
16 | while循环语句中的if嵌套
17 | 字典的定义和常用操作
18 | 列表推导式与字典推导式
19 | 文件的内建函数
20 | 文件的常用操作
21 | 异常的检测和处理
22 | 函数的定义和常用操作
23 | 函数的可变长参数
24 | 函数的变量作用域
25 | 函数的迭代器与生成器
26 | Lambda表达式
27 | Python内建函数
28 | 闭包的定义
29 | 闭包的使用
30 | 装饰器的定义
31 | 装饰器的使用
32 | 自定义上下文管理器
33 | 模块的定义
34 | PEP8编码规范
35 | 类与实例
36 | 如何增加类的属性和方法
37 | 类的继承
38 | 类的使用-自定义with语句
39 | 多线程编程的定义
40 | 经典的生产者和消费者问题
41 | Python标准库的定义
42 | 正则表达式库re
43 | 正则表达式的元字符
44 | 正则表达式分组功能实例
45 | 正则表达式库函数match与search的区别
46 | 正则表达式库替换函数sub()的实例
47 | 日期与时间函数库
48 | 数学相关库
49 | 使用命令行对文件和文件夹操作
50 | 文件与目录操作库
51 | 机器学习的一般流程与NumPy安装
52 | NumPy的数组与数据类型
53 | NumPy数组和标量的计算
54 | NumPy数组的索引和切片
55 | pandas安装与Series结构
56 | Series的基本操作
57 | Dataframe的基本操作
58 | 层次化索引
59 | Matplotlib的安装与绘图
60 | 机器学习分类的原理
61 | Tensorflow的安装
62 | 根据特征值分类的模型和代码
63 | 网页数据的采集与urllib库
64 | 网页常见的两种请求方式get和post
65 | HTTP头部信息的模拟
66 | requests库的基本使用
67 | 结合正则表达式爬取图片链接
68 | Beautiful Soup的安装和使用
69 | 使用爬虫爬取新闻网站
70 | 使用爬虫爬取图片链接并下载图片
强势回归:零基础学Python2022版来啦!
71 | 如何分析源代码并设计合理的代码结构&结课测试
本节摘要

课程源码、课件及课后作业地址:

https://gitee.com/geektime-geekbang/geekbangpython

登录 后留言

全部留言(7)

  • 最新
  • 精选
Jarvis
match() 不匹配出来不是什么完全不完全,是因为 match 必须从字符串开头进行匹配,相当于自带了一个 ^

作者回复: 这个解释相当精辟,它是依据正则来匹配的。但是还有很多对正则符号不熟悉的同学,所以在视频中没用这种方式解释一个新的概念。

2019-02-11
7
彬(^_^)
老师这里有个问题: p1 = re.compile(r'(\d+)-(\d+)-(\d+)') print('search1:',p1.search('asd2019-3-1sdf')) print('search2:',p1.search('asd2019-as3-1sdf')) print('search3:',p1.search('asd2019-3sd-1df')) 返回: search1: <_sre.SRE_Match object; span=(3, 11), match='2019-3-1'> search2: None search3: None search不是对需要匹配的值进行搜索吗,为什么后面两种返回的是None

作者回复: 没有匹配成功所以返回了NONE

2019-03-21
源哥60
# [abc]只匹配枚举的字符(范围写法:[1-9],[a-z]) print('13------',re.compile('c[abc]t').search('1cbt2'),re.compile('c[abc]t').search('cdt'),re.compile('c[1-9]t').search('c6t')) # | 左边整体或右边整体 print('14------',re.compile('c[abc]|5t').search('1cbjj2'),re.compile('c[abc]|5t').search('1c995t2y'),re.compile('c[abc]|5t').search('1cht2')) # \s 任意单空白符,等价于 [\t\n\r\f\v],\S 任意非空白符 print('15------',re.compile('c\st').search('1c th'),re.compile('c\s+t').search('1c tu'),re.compile('c\st').search('1ctu')) # \d 数字单字符,同[123456789]=[1-9]=\d print('16------',re.compile('c\dt').search('1c5th'),re.compile('c\dt').search('1c57th'),re.compile('c\d{3,}t').search('1c5778th')) # \D 非数字单字符 print('17------',re.compile('c\Dt').search('1c5th'),re.compile(r'c\Dt').search('1c-th')) # ()用于分组,\数字 分组引用 print('18------',re.compile(r'(cat)\1').search('catcat')) # | 左边整体或右边整体 print('19------',re.compile(r'c(123|456)t').search('c123t'),re.compile(r'c(123|456)t').search('c456t'),re.compile(r'c(123|456)t').search('c123456t')) # .*? 不使用贪婪模式 (无问号则会贪婪匹配) print('20------',re.compile(r'cat.*?').search('cat123'),re.compile(r'cat.*').search('cat123'),re.compile(r'cat.*?').search('cat')) # 小玩法,年月日1 print('21------',re.compile(r'\d{4}-\d{2}-\d{2}').search('2021-08-01')) # 小玩法,年月日2 print('22------',re.compile(r'\d+-\d+-\d+').search('2021-08-01')) # 分组后取出 print('23------',re.compile(r'(\d+)-(\d+)-(\d+)').search('2021-08-01').group(1)) print('24------',re.compile(r'(\d+)-(\d+)-(\d+)').search('2021-08-01').group(2)) print('25------',re.compile(r'(\d+)-(\d+)-(\d+)').search('2021-08-01').group(3)) print('26------',re.compile(r'(\d+)-(\d+)-(\d+)').search('2021-08-01---2021-08-02').groups())
2021-08-01
1
o0oi1i
打卡45
2020-02-27
农夫山泉
问下老师,python3调用java的jar包时遇到com.p4.pt这种路径该怎么调用,用开发工具打开jar包时这个路径在同一阶层,连着的,就像我写的这样,所以调用时这个路径该怎么写
2019-10-24
Geek_b498b7
请问老师为什么如果月份或日期前出现字母的话用search也匹配不了?
2019-10-03
1
NO.9
无意间发现{}写都位置会对结果产生很多影响 ,如下两个正则都group出力看很有意思 p = re.compile('(\d+)-(\d+)-(\d+)') pr = re.compile(r'(\d){4}-(\d){2}-(\d{2})') #注意{}位置 print('p 1', p.match('2018-01-01')) print('p 2', p.match('2018-1-01')) print('pr ', pr.match('2018-01-01')) 以下都出力对比看很有意思{n}写在()内外会对用取得的长度有影响 print('p groups():', p.match('2018-01-01').groups()) print('p group() :', p.match('2018-01-01').group()) print('p group(0):', p.match('2018-01-01').group(0)) print('p group(1):', p.match('2018-01-01').group(1)) print('p group(2):', p.match('2018-01-01').group(2)) print(':***************************') print('pr groups():', pr.match('2018-01-01').groups()) print('pr group() :', pr.match('2018-01-01').group()) print('pr group(0):', pr.match('2018-01-01').group(0)) print('pr group(1):', pr.match('2018-01-01').group(1)) print('pr group(2):', pr.match('2018-01-01').group(2)) output:---------------------------------- p 1 <_sre.SRE_Match object; span=(0, 10), match='2018-01-01'> p 2 <_sre.SRE_Match object; span=(0, 9), match='2018-1-01'> pr <_sre.SRE_Match object; span=(0, 10), match='2018-01-01'> p groups(): ('2018', '01', '01') p group() : 2018-01-01 p group(0): 2018-01-01 p group(1): 2018 p group(2): 01 :*************************** pr groups(): ('8', '1', '01') ->{}在()外面只取得一位 pr group(): 2018-01-01 pr group(0): 2018-01-01 pr group(1): 8 pr group(2): 1
2019-08-18
收起评论