零基础学 Python(2018 版)
尹会生
前游戏公司技术总监,前新浪网技术经理
80146 人已学习
新⼈⾸单¥68
课程目录
已完结/共 72 讲
第一章 :Python介绍和安装 (3讲)
第二章 :Python基础语法 (3讲)
第四章 :条件与循环 (5讲)
第五章 :映射与字典 (2讲)
第六章 :文件和输入输出 (2讲)
第七章 :错误和异常 (1讲)
第九章 :模块 (1讲)
第十章 :语法规范 (1讲)
第十一章 :面向对象编程 (4讲)
第十二章 :多线程编程 (2讲)
第十六章 :综合案例 & 结课测试 (1讲)
特别放送 (1讲)
零基础学 Python(2018 版)
登录|注册
留言
5
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 46 | 正则表达式库替换函数sub()的实例
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

登录 后留言

全部留言(5)

  • 最新
  • 精选
卡本
请问老师,findall感觉更像是search的拓展,那findall可以用于match和sub么?感觉findall这块不太明白,谢谢老师~

作者回复: findall、match、sub、match分别是不同的函数功能,并非是扩展,例如search函数是找到第一个匹配的字符串,findall是找到所有匹配的字符串 根据需要使用不同的函数。如下: import re string = "x abc y 123 z 123" pattern = re.compile(r'\d+') print(re.search(pattern,string)) print(pattern.findall(string)) # 输出结果 # <re.Match object; span=(8, 11), match='123'> # ['123', '123'] 这些函数之间都可以配合使用的。

2018-11-28
3
Geek_216fd5
以下代码里,r并未把‘\n’过滤掉,为什么 ? 如何才能过滤掉 ? import re phone = '010-88769878 # 这是电话号码\n' p2 = re.sub(r'#.*$', '', phone) print(p2) print('-----')

作者回复: 问题原因: \n是转义字符字符,默认的re.sub()会让转义字符先转义,再正则匹配 解决办法: def sub(pattern, repl, string, count=0, flags=0): sub函数第四个参数叫做标志位,可以使用 re.S 使.匹配包括换行在内的所有字符 re.I 忽略大小写,re.M 多行匹配等功能 将 p2 = re.sub(r'#.*$', '', phone) 这行增加关键字参数 p2 = re.sub(r'#.*$', '', phone, flags=re.S) 可以实现用.匹配\n

2020-07-27
2
王安
re里面的转移字符r是不是只能把正则表达式那一层需要的转义取消掉。

作者回复: r是声明这个字符串里面是正则表达式的元字符

2020-02-01
浪费的时间
菜鸟教程了解下
2020-02-10
1
Geek_a8e4ec
我们学了match和search的知识,去猜想或者自己练习findall。这是一把双刃剑。练得好,信心倍增;练得不好,泰山压顶。学习吃饭能力的例子并对其加以复用,而不是对“findall”的挑战加以努力。否则,我花钱了,还得花时间和脑子,又来“尝试,猜测与爆破”。。我出钱,你出力。。一人出一样。。老师,多来干货呀。。 p = re.compile(r'(\d+)-(\d+)-(\d+)') print (p.findall('aa2018-05-10bb2018-05-11'))
2022-08-22
收起评论