查看内存地址
print(id(a4[2]))
print(id(b4[2]))
修改数据
a4[2][0] = 6
子对象的数据会受影响
print(a4)
print(b4)
2.深拷贝
import copy # 使用深拷贝需要导入copy模块
不可变类型有: 数字、字符串、元组
a1 = 1
b1 = copy.deepcopy(a1) # 使用copy模块里的deepcopy()函数就是深拷贝了
查看内存地址
print(id(a1))
print(id(b1))
print(“-” * 10)
a2 = “张三”
b2 = copy.deepcopy(a2)
查看内存地址
print(id(a2))
print(id(b2))
print(“-” * 10)
a3 = (1, 2)
b3 = copy.deepcopy(a3)
查看内存地址
print(id(a3))
print(id(b3))
print(“-” * 10)
注意: 元组里面要是有可变类型对象,发现对象有可变类型就会该对象到最后一个可变类型的每一层对象进行拷贝
a4 = (1, [“李四”])
b4 = copy.deepcopy(a4)
查看内存地址
print(id(a4))
print(id(b4))
元组里面的可变类型子对象也会进行拷贝
print(id(a4[1]))
print(id(b4[1]))
可变类型的深拷贝示例代码:
import copy # 使用深拷贝需要导入copy模块
可变类型有: 列表、字典、集合
a1 = [1, 2]
b1 = copy.deepcopy(a1) # 使用copy模块里的deepcopy()函数就是深拷贝了
查看内存地址
print(id(a1))
print(id(b1))
print(“-” * 10)
a2 = {“name”: “张三”}
b2 = copy.deepcopy(a2)
查看内存地址
print(id(a2))
print(id(b2))
print(“-” * 10)
a3 = {1, 2}
b3 = copy.deepcopy(a3)
查看内存地址
print(id(a3))
print(id(b3))
print(“-” * 10)
a4 = [1, 2, [“李四”, “王五”]]
b4 = copy.deepcopy(a4) # 使用copy模块里的deepcopy()函数就是深拷贝了
查看内存地址
print(id(a4))
print(id(b4))
查看内存地址
print(id(a4[2]))
print(id(b4[2]))
a4[2][0] = “王五”
因为列表的内存地址不同,所以数据不会收到影响
print(a4)
print(b4)
3.浅拷贝和深拷贝的区别
4.总结
五、正则表达式的概述
1.正则表达式的介绍
2.正则表达式概念
正则表达式就是记录文本规则的代码
3.正则表达式的样子
0\d{2}-\d{8} 这个就是一个正则表达式,表达的意思是匹配的是座机号码
4.正则表达式的特点
5.小结
正则表达式是匹配符合某些规则的字符串数据
六、re模块介绍
1.re模块的介绍
2. re模块的使用
3.小结
re.match() 根据正则表达式从头开始匹配字符串数据
七、匹配单个字符
1.匹配单个字符
示例2:[]
import re
如果hello的首字符小写,那么正则表达式需要小写的h
ret = re.match(“h”,“hello Python”) print(ret.group())
如果hello的首字符大写,那么正则表达式需要大写的H
ret = re.match(“H”,“Hello Python”) print(ret.group())
大小写h都可以的情况
ret = re.match(“[hH]”,“hello Python”) print(ret.group()) ret = re.match(“[hH]”,“Hello Python”) print(ret.group()) ret = re.match(“[hH]ello Python”,“Hello Python”) print(ret.group())
匹配0到9第一种写法
ret = re.match(“[0123456789]Hello Python”,“7Hello Python”) print(ret.group())
匹配0到9第二种写法
ret = re.match(“[0-9]Hello Python”,“7Hello Python”) print(ret.group()) ret = re.match(“[0-35-9]Hello Python”,“7Hello Python”) print(ret.group())
下面这个正则不能够匹配到数字4,因此ret为None
ret = re.match(“[0-35-9]Hello Python”,“4Hello Python”)
print(ret.group())
示例3:\d
import re
普通的匹配方式
ret = re.match(“嫦娥1号”,“嫦娥1号发射成功”) print(ret.group()) ret = re.match(“嫦娥2号”,“嫦娥2号发射成功”) print(ret.group()) ret = re.match(“嫦娥3号”,“嫦娥3号发射成功”) print(ret.group())
使用\d进行匹配
ret = re.match(“嫦娥\d号”,“嫦娥1号发射成功”) print(ret.group()) ret = re.match(“嫦娥\d号”,“嫦娥2号发射成功”) print(ret.group()) ret = re.match(“嫦娥\d号”,“嫦娥3号发射成功”) print(ret.group())
2.小结
八、匹配多个字符
1.匹配多个字符
2.小结
九、匹配开头和结尾
1.匹配开头和结尾
2.除了指定字符以外都匹配
3.小结
十、匹配分组
1.匹配分组相关正则表达式
感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的:
① 2000多本Python电子书(主流和经典的书籍应该都有了)
② Python标准库资料(最全中文版)
③ 项目源码(四五十个有趣且经典的练手项目及源码)
④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)
⑤ Python学习路线图(告别不入流的学习)