一. 二进制数据的转换

1.二进制类型/字节(bytes)

2.其他数据转二进制:bytes(数据)

3.字符串转二进制:字符串.encode(encoding=‘utf-8’)

print(bytes(10))   # b'\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00'
# print(bytes(12.5))   # TypeError: cannot convert 'float' object to bytes
print(bytes(True))   # b'\x00'print(bytes('abc', encoding='utf-8'))   # b'abc'print(bytes([1, 2]))   # b'\x01\x02'
# print(bytes(['abc', '13']))   # TypeError: 'str' object cannot be interpreted as an integerlist1 = [100, 'abc', 12.5]
b1 = bytes(str(list1), encoding='utf-8')
print(b1)   # b"[100, 'abc', 12.5]"

4.二进制转字符串:

# 方法一:str(数据, encoding='utf-8')
str1 = str(b1, encoding='utf-8')
print(str1)
list1 = eval(str1)
print(list1)   # [100, 'abc', 12.5]str2 = 'hello'
b2 = str2.encode(encoding='utf-8')
print(b2)   # b'hello'# 方法二:二进制数据.decode(encoding=;'utf-8')
str2 = b2.decode(encoding='utf-8')
print(str2)   # hello

二. 正则语法

from re import fullmatch, search, findall, I, S, M

1.什么是正则表达式

"""
正则表达式是一种工具;一种专门用来做字符串匹配的工具,能够在某些情况下让字符串的处理变的非常简单
正则是用来描述字符串规则fullmatch(正则表达式, 字符串) - 判断正则表达式是否和字符串完全匹配,如果不匹配返回None
"""

2.正则表达式的语法(通用的)

# ==================匹配符号=====================

1)普通字符

"""
普通字符在正则表达式中表示这个符号本身
"""
# 匹配一个字符串有三个字符,分别是a、b、c
re_str = r'abc'
result = fullmatch(re_str, 'abc')
print(result)  # <_sre.SRE_Match object; span=(0, 3), match='abc'>

2).   -  匹配任意一个字符

# 2).   -   匹配任意一个字符(换行(\n)为特殊情况)
# 多行匹配(默认,符号为M):.不能匹配\n;单行匹配(符号为S):.可以匹配\n
# 如何变成单行匹配:a.flags=S(需先从re模块中导入变量S)
#                  b.(?s)
# 单行匹配
print(fullmatch(r'a.b', 'a\nb', flags=S))
print(fullmatch(r'(?s)a.b', 'a\nb'))# 多行匹配
print(fullmatch(r'a.b', 'a\nb', flags=M))
print(fullmatch(r'(?m)a.b', 'a\nb'))# 忽略大小写(变量I,需先从re模块中导入)
print(fullmatch(r'abc', 'ABC', flags=I))
print(fullmatch(r'(?i)abc', 'ABC'))# 忽略大小写并且单行匹配
print(fullmatch(r'a.b', 'A\nb', flags=I | S))
print(fullmatch(r'(?is)a.b', 'A\nb'))
# 匹配一个长度是3的字符串,第一个字符是任意字符,后面是bc
re_str = r'.bc'
re_str = fullmatch(re_str, 'xbc')
print(result)

3)\d  -  匹配任意一个数字字符

re_str = r'\d\d\d'
result = fullmatch(re_str, '782')
print(result)

4)\D  -  匹配任意一个非数字字符

re_str = r'\d\D\d'
result = fullmatch(re_str, '8h0')
print(result)

5)\s   -  匹配任意一个空白字符

# 空白字符:空格、\n(换行)、\t(制表符)
re_str = r'abc\s123'
print(fullmatch(re_str, 'abc 123'))

6)\S  -  匹配任意一个非空白字符

re_str = r'abc\S\d'
print(fullmatch(re_str, 'abc*7'))

7)\w  -  匹配任意一个数字、字母或者下划线(不好用,非ASCII码中的字符都可以匹配)

8)[字符集]  -  匹配字符集中出现的任意一个字符

"""
注意:一个[]只能匹配一个字符[abc]   -   匹配一个字符是a或者b或者c
[\dabc] -   匹配一个字符就是数字或者a或者b或者c[1-9]   -   匹配1到9的任意一个数字字符
[a-z]   -   匹配任意一个小写字母
[a-zA-Z]    -   匹配任意一个字母
[\da-zA-Z_]  -   匹配字母、数字、下划线
[\u4e00-\u9fa5] -   匹配任意一个中文字符
"""
re_str = r'[abc]123'
print(fullmatch(re_str, 'a123'))# -在[]中两个字符之间才有特殊意义
re_str = r'[-abc]12-3'
print(fullmatch(re_str, '-12-3'))

9)[^字符集]  -  匹配不在字符集中的任意一个字符

"""
[^abc]  -   匹配除了abc以外的任意一个字符
[^\dxy]   -   匹配除了xy和数字以外的任意一个字符[^a-z]  -   匹配除了小写字母以外的任意一个字符
"""
print(fullmatch(r'[^abc]123', 'm123'))
print(fullmatch(r'[\u4e00-\u9fa5]123', '类123'))
print(fullmatch(r'[^\u4e00-\u9fa5]123', 'k123'))# 注意:^在[]中如果没有在开头就表示这个符号本身
print(fullmatch(r'[a^bc]123', '^123'))
# ==================检测符号=====================# 匹配符号要求一个符号必须对应一个字符,会影响字符串长度的描述;
# 检测符号,不会匹配字符也不会影响字符串的长度,它是在匹配成功的前提下对指定位置的字符进行检测

1)\b  -  检测是否是单词边界

"""
单词边界    -   所有能够区分出两个不同单词的符号,例如:空白字符、标点符号、字符串开头和结尾
"""
re_str = r'abc\b\s123'
print(fullmatch(re_str, 'abc 123'))

2)\B  -  检测是否不是单词边界

re_str = r'abc\B123'
print(fullmatch(re_str, 'abc123'))

3)^  -  检测是否是字符串开头

re_str = r'abc^123'
print(fullmatch(re_str, 'abc123'))  # Nonere_str = r'^abc123'
print(fullmatch(re_str, 'abc123'))

4)$  -  检测是否是字符串结尾

# ===============匹配次数================

1)*  -  0次或多次

"""
a*  -   字符a出现0次或者多次
\d* -   任意数字出现0次或多次(实质是\d在正则中出现0次或多次)
[字符集]*  -   字符集中的任意字符出现0次或者多次(每次都可以是任意一个)
"""
re_str = r'a*bc'
print(fullmatch(re_str, 'bc'))
print(fullmatch(re_str, 'abc'))re_str = r'a\d*c'
print(fullmatch(re_str, 'ac'))
print(fullmatch(re_str, 'a1c'))
print(fullmatch(re_str, 'a123c'))re_str = r'a[A-Z]*c'
print(fullmatch(re_str, 'ac'))
print(fullmatch(re_str, 'aASDFc'))

2)+  -  1次或多次(至少1次)

re_str = r'a[A-Z]+c'
print(fullmatch(re_str, 'ac'))  # None
print(fullmatch(re_str, 'aASDFc'))

3)?  -  0次或1次

# 练习:写一个正则能匹配任意正整数:23,3490,+87,023(None)
re_str = r'[+]?[1-9]\d*'
print(fullmatch(re_str, '53'))

4){}

"""
{N} -   匹配N次
{M,N}   -   匹配M到N次
{M,}    -   匹配至少M次
{,N}    -   匹配至多N次
"""
re_str = r'\d{3}'
print(fullmatch(re_str, '798'))# 用户名的要求:全部由数字或者字母组成,长度是3~6位
re_str = r'[\da-zA-Z]{3,6}'
print(fullmatch(re_str, '154sdf'))

5)贪婪和非贪婪

"""
在匹配次数不确定的时候匹配模式有两种:贪婪(默认)和非贪婪(在不确定次数后面加?)贪婪:在能匹配成功的前提下,匹配次数选最多的(+、*、?、{M,N}、{M,}、{,N})
非贪婪:在能匹配成功的前提下,匹配次数选最少的(+?、*?、??、{M,N}?、{M,}?、{,N}?)
"""
# 贪婪模式
re_str = r'a.+b'
print(search(re_str, 'xxamnbpppb山单反b====='))  # 'amnbpppb山单反b'# 非贪婪模式
re_str = r'a.+?b'
print(search(re_str, 'xxamnbpppb山单反b====='))  # 'amnb'
# ===============分组================

1)()

"""
用法一:整体操作
a{2,3}
(ab){2,3}用法二:重复
\M  -   重复前面第M个分组中匹配到的内容用法三:捕获
re中的findall在获取字串的时候,如果正则中有分组,只会获取分组匹配到的结果
"""
# 两个数字两个字母的结构重复重复3到5次:类似:89sd78xd32fd
print(fullmatch(r'(\d{2}[a-z]{2}){3,5}', '89sd78xd32fd'))
# ===============分支================

1)|

"""
正则1|正则2|正则3...
先用正则1进行匹配,如果匹配成功整个正则就匹配成功;如果失败就用正则2进行匹配,如果成功整个正则就匹配成功
如果失败就用正则3进行匹配,以此类推...
"""
# 写一个正则能够匹配一个字符串:abc后面是三个数字或者abc后面是三个大写字母
re_str = r'abc\d{3}|abc[A-Z]{3}'
print(fullmatch(re_str, 'abc321'))re_str = r'abc(\d{3}|[A-Z]{3})'
print(fullmatch(re_str, 'abcSKD'))
# ===============转义符号================
"""
在正则中有特殊意义的符号前加\,让这个符号在正则中的功能消失。
"""
re_str = r'\d{2}\.\d{2}'
print(fullmatch(re_str, '23.45'))# 注意:在正则中独立存在有特殊意义的符号,放到[]中,它的意义会自动消失

三. re模块的使用

import re

1.编译

# compile(正则表达式)  -   编译正则表达式,返回正则对象
re_obj = re.compile(r'\d{3}')
# 正则表达式对象.fullmatch(字符串)
print(re_obj.fullmatch('789'))

2.匹配

"""
fullmatch(正则, 字符串)  -   让整个字符串和正则进行匹配,匹配失败返回None,匹配成功返回匹配对象
match(正则, 字符串)  -   让字符串的开头和正则进行匹配,匹配失败返回None,匹配成功返回匹配对象
"""
print(re.match(r'\d{3}', '654sdfsdf==='))

匹配对象

result = re.match(r'(\d{2})([a-z]{3})([A-Z]{2})', '36knmHK山反')
print(result)

1)匹配到的字串

# 匹配对象.group() / 匹配对象.group(0)  -   获取整个正则匹配到的字串
# 匹配对象.group(N) -   获取第N个分组匹配到的字串print(result.group())   # '36knmHK'
print(result.group(1))   # '36'
print(result.group(3))   # 'HK'

2)获取匹配范围 - 匹配到的字串在原字符串中的下标范围

# 匹配对象.span()
print(result.span())   # [0, 7)
print(result.span(2))   # [2, 5)

3.查找

"""
search(正则, 字符串)     -   在字符串查找第一个满足正则的字串,如果找到了返回匹配对象,如果找不到返回None
findall(正则, 字符串)    -   获取字符串中所有满足正则的字串,返回值是列表,列表中的元素是字符串,如果找不到则返回空列表
re.finditer(正则, 字符串)    -   获取字符串中所有满足正则的字串,返回值是迭代器,迭代器中的元素是匹配对象
"""
# 1)search
print(re.search(r'\d{3}', 'sdfj789sdhf753山单反'))
# 2)findall
# 没有分组
print(re.findall(r'\d{3}', 'sdfj789sdhf753山单反'))   # ['789', '753']# 有分组
print(re.findall(r'a(\d{3})', 'abm678sdfka092sdfjgg===-a786sdfsa119'))   # ['092', '786', '119']# 有两个或者两个以上的分组:[('bm', '678'), ('ka', '092'), ('sa', '119')]
print(re.findall(r'([a-z]{2})(\d{3})', 'abm678sdfka092sdfjgg===-a786sdfsa119'))   # ['bm678', 'ka092', 'sa119']
# 3)finditer
result = re.finditer(r'([a-z]{2})(\d{3})', 'abm678sdfka092sdfjgg===-a786sdfsa119')   # ['bm678', 'ka092', 'sa119']
print(result)
print(list(result))

4.切割和替换

"""
split(正则, 字符串)  -   将字符串中满足正则的字串作切割点
sub(正则, 字符串1, 字符串2) -   将字符串2中满足正则的字串全部替换成字符串1
"""
result = re.split(r'\d+', 'sdfasdf465sdfwersdf133')
print(result)result = re.sub(r'\d', '+', 'sdfasdf465sdfwersdf133')
print(result)

小白学习Python的第十六天之正则表达式相关推荐

  1. python课程思路_学习python课程第二十六天

    一.    传输层 在上述三层协议中我们,ip协议帮我们定位到子网络. mac地址帮我们定位到一台计算机,并与其通讯, 但本质上,计算机的通讯是为了应用程序能够通讯,而一台计算机上不可能运行一个应用程 ...

  2. 孤荷凌寒自学python第五十六天通过compass客户端和mongodb shell 命令来连接远端MongoDb数据库...

    孤荷凌寒自学python第五十六天通过compass客户端和mongodb shell 命令来连接远端MongoDb数据库 (完整学习过程屏幕记录视频地址在文末) 今天是学习mongoDB数据库的第二 ...

  3. python多久能上手_小白学习Python,怎样能够快速入门上手

    原标题:小白学习Python,怎样能够快速入门上手 时至今日,Python已经成为最受欢迎的编程语言之一,清晰易读,适用广泛.在TIOBE 排行榜中位居第四,成为名副其实的人工智能第一语言. 那么零基 ...

  4. 小白学python买什么书-终于明白小白学习python怎么学

    Python作为一门新型的编程语言(一般常用作脚本语言)很受欢迎,毕竟相对其他的编程语言(Java ,C#等)来说比较容易入手.那么,在刚开始学习Python时有哪些疑难点需要掌握呢?以下是小编为你整 ...

  5. python语言自学-零基础小白学习Python编程语言的正确姿势(纯干货)

    原标题:零基础小白学习Python编程语言的正确姿势(纯干货) 敢问有哪种编程语言集简洁.优雅.简单.全能于一身?Python绝对算的上是一个.举个例子,比如完成同一个任务,C语言需要写1000行代码 ...

  6. python中小学生编程学习-推荐几个适合小白学习Python的免费网站

    9gd少儿编程网-Scratch_Python_教程_免费儿童编程学习平台 想要学好python,只靠看Python相关的书籍是远远不够的!互联网时代,我们还要充分利用网络上的免费资源,不然怎样成为一 ...

  7. python自学网站免费-推荐几个适合小白学习Python的免费网站

    9gd少儿编程网-Scratch_Python_教程_免费儿童编程学习平台 想要学好python,只靠看Python相关的书籍是远远不够的!互联网时代,我们还要充分利用网络上的免费资源,不然怎样成为一 ...

  8. python调用vb文件_Python小白学习之路(十九)—【文件操作步骤】【文件操作模式】...

    一.文件操作步骤 step1:打开文件,得到文件句柄并赋值给一个变量 step2:通过句柄对文件进行操作 step3:关闭文件 举例: a= open('hello world', 'r', enco ...

  9. 小白学习python好还是java好_小白应该学Python还是Java?

    Java和Python两门语言都是目前非常热门的语言,可谓北乔峰南慕容,二者不分上下,棋逢对手.但是对于初学者来说,非常困惑,因为时间和精力有限,上手必须要先学一门,到底选那个好呢,今天3分钟带你透彻 ...

最新文章

  1. 【Java】使用单向链表实现一个队列(Queue)
  2. minicom HOWTO
  3. QT中关于头文件一个很奇怪的问题
  4. 三支一扶计算机公共基础知识,三支一扶公共基础知识教材(精华版).doc
  5. 集群节点数和分片数关系_完全二叉树的节点数,你真的会算吗?
  6. SAP Spartacus State
  7. pitr 原理_PostgreSQL热备原理研究及流复制运用
  8. /etc/profile、/etc/bashrc、~/.bash_profile、~/.bashrc 文件的作用
  9. linux未使用磁盘空间满,linux磁盘空间用满的处理方法
  10. java win 窗体开发简单订餐系统_Java实现简单订餐系统
  11. MyBaits动态sql语句
  12. 批处理禁用U盘,光驱,用户添加到组,盘符添加权限
  13. 蓝桥杯 算法训练 数的潜能 正整数分解使得乘积最大问题
  14. 陈世清C语言程序设计课后答案,c语言程序设计报告.doc
  15. AtCoder Beginner Contest 177 A~D 题解
  16. v$active_session_history的wait_time和time_waited 列(转)
  17. (E1)ENVI-met介绍及下载
  18. python中使用python-dotenv管理环境变量
  19. msgbox窗口学习总结窗体复合框
  20. 微信小程post问题

热门文章

  1. Ubuntu 使用Thunderbird 加载Exchange类型的邮箱
  2. 我的 Mac 终端配置(Mac OSX + iTerm2 + Zsh + Oh-My-Zsh)
  3. 77.Oozie的HA启用
  4. 解决 操作必须使用一个可更新的查询的错误
  5. 再上一发逻辑炸弹,不一样哦
  6. #个人日记-电影《哆啦A梦:伴我同行2》观后感-20210530
  7. 闵行区科技小巨人工程申请条件及奖励政策解读
  8. 四川大地震将是中国社会的转折点
  9. 计算机人物系列-约翰·冯·诺依曼
  10. 神策 2019 数据驱动大会,引领大数据行业“矩•变”升级