一.基础数据类型的补充

1.其他类型之间的相互转换

例如:str = int(str) str => int;

   int = list(int) int => list;

   tuple = dict(tuple) tuple => dict;

但是:str => list时用的是str = str.split(元素)

   list => str时用的是str = 元素.join(list)

代码展示:

  1. s = "|".join(["美国往事","当幸福来敲门","穿靴子的猫"])
  2. print(s)
  3. s = s.split("|")
  4. print(s)
  5. #输出结果:
  6.  
  7. 美国往事|当幸福来敲门|穿靴子的猫
  8.  
  9. ['美国往事', '当幸福来敲门', '穿靴子的猫']

二.关于for的一些解释

1.for在运行的过程中,会有一个指针来记录当前循环的元素是哪一个,一开始这个指针指向第0个,

然后获取到第0个,紧接着删除第0个,这个时候,原来是第一个的元素会自动的变成第0个,然后指针向后移动一次,指向1元素,这时所有元素向前移了一位.

2.总结:字典,列表在for循环过程中,不论是del还是remove,pop都不能实现

3.怎样在for循环的过程中删除元素:

代码展示:

  1. lst = ["周杰伦","周润发","周星星","马化腾"]
  2. li = []
  3. for i in lst:
  4. if i.startswith("周"):
  5. li.append(i)
  6. for c in li:
  7. lst.remove(c)
  8. print(lst)
  9. #输出结果:['马化腾']

这是把以"周"开头的字符串去除掉;

(1)要新建一个列表,先把符合条件的添加进列表,

(2)然后再遍历该列表,用原来的列表删除遍历到的新列表赋值给变量c的字符串;

*注意转成False的数据:

0,"",None,[],(),{},set() ==>False;

三.set集合

1.set最大的的用处就是去除集合中的重复;set中的元素必须是可哈希的(int,str,tuple,bool);

所以列表,字典,和set(set本身是不可hash的.set是可变的),set中得元素也是无序的;

  1. set1 = {'','alex',2,True,[1,2,3]} # 报错
  2. set2 = {'','alex',2,True,{1:2}} # 报错
  3. set3 = {'','alex',2,True,(1,2,[2,3,4])} # 报错

2.1 增加

代码展示:

  1. s = {"刘嘉玲", '关之琳', "王祖贤"}
  2. s.add("郑裕玲")
  3. print(s)
  4. s.add("郑裕玲") # 重复的内容不不会被添加到set集合中
  5. print(s)
  6. #集合和字典长得很像,但是没有key和value;

2.2 删除

s.remove(元素)#直接删除元素;

s.pop()#随机

3.常用操作:

s1 = {"刘能", "赵四", "⽪皮⻓长⼭山"}

s2 = {"刘科⻓长", "冯乡⻓长", "⽪皮⻓长⼭山"}

# 交集 # 两个集合中的共有元素

print(s1 & s2)  #结果: {'⽪皮⻓长⼭山'}

print(s1.intersection(s2))  # 结果:{'⽪皮⻓长⼭山'}

# 并集

print(s1 | s2) # {'刘科⻓长', '冯乡⻓长', '赵四', '⽪皮⻓长⼭山', '刘能'}

print(s1.union(s2)) # {'刘科⻓长', '冯乡⻓长', '赵四', '⽪皮⻓长⼭山', '刘能'}

# 差集

print(s1 - s2) # {'赵四', '刘能'} 得到第⼀个中单独存在的

print(s1.difference(s2)) # {'赵四', '刘能'}

# ⼦集

print(s1 < s2) # set1是set2的⼦子集吗? True

print(s1.issubset(s2))

# 超集

print(s1 > s2) # set1是set2的超集吗? False

print(s1.issuperset(s2))

三.深浅拷贝

1.浅拷贝

从图可以看出:在列表进行赋值时,两个列表对应一个内存地址的对象;一个列表发生改变,那另一个列表也发生相应改变;

总结:对于列表和字典来说,直接赋值,其实是把内存地址交给变量,并不是复制了一份,所以列表1和列表2的指向是一样的;

浅拷贝格式:lst2 = lst1.copy() print(id(lst1),id(lst2))这时候两个列表内存地址就不一样了,而不互相影响;

代码展示:

  1. lst = ["周杰伦","周润发","周星星","马化腾"]
  2. lst1 = lst.copy()
  3. lst1.append("马鹏林")
  4. print(lst,id(lst))
  5. print(lst1,id(lst1))
  6. #输出结果
  7. ['周杰伦', '周润发', '周星星', '马化腾'] 2259879557704
  8. ['周杰伦', '周润发', '周星星', '马化腾', '马鹏林'] 2259879558408

两个列表不一样,而且内存地址不一样;浅拷贝只会拷贝第一层,所以称为浅拷贝;

浅拷贝还有一种格式:

  1. lst1 = ["赵本山", "刘能", "赵四"]
  2. lst2 = lst1[:] # 切片会产生新的对象
  3. lst1.append("谢大脚")
  4. print(lst1,id(lst1))
  5. print(lst2,id(lst2))
  6. #输出结果:
  7. ['赵本山', '刘能', '赵四', '谢大脚'] 1400279607368
  8. ['赵本山', '刘能', '赵四'] 1400280414792

所以通过上面可以看出,切片也可以进行浅拷贝;切片相当于从源列表copy出一段范围,成为新的列表;

2.深拷贝

  1. lst1 = ["超人", "七龙珠", "葫芦娃", ["王力宏", "渣渣辉"]]
  2. lst2 = lst1.copy() # 拷贝. 浅拷贝 拷贝第一层
  3. lst1[3].append("大阳哥")
  4. print(lst1,id(lst1[3]))
  5. print(lst2,id(lst2[3]))
  6. #输出结果:
  7. ['超人', '七龙珠', '葫芦娃', ['王力宏', '渣渣辉', '大阳哥']] 1172889937992
  8. ['超人', '七龙珠', '葫芦娃', ['王力宏', '渣渣辉', '大阳哥']] 1172889937992

从上面可以看出,浅拷贝只拷贝第一层,所以列表1和列表2的地址是一样的;

引出深拷贝:

代码展示:

  1. #深拷贝
  2. import copy
  3. lst1 = ["超人", "七龙珠", "葫芦娃", ["王力宏", "渣渣辉"]]
  4. lst2 = copy.deepcopy(lst1) # 把lst1扔进去进行深度拷贝 , 包括内部的所有内容进行拷贝
  5. lst1[3].append("大阳哥")
  6. print(lst1,id(lst1[3]))
  7. print(lst2,id(lst2[3]))
  8. #输出:
  9. ['超人', '七龙珠', '葫芦娃', ['王力宏', '渣渣辉', '大阳哥']] 3012638897480
  10. ['超人', '七龙珠', '葫芦娃', ['王力宏', '渣渣辉']] 3012638898888

Python_007(深浅拷贝)的更多相关文章

  1. Python 从零学起(纯基础) 笔记 之 深浅拷贝

    深浅拷贝 1. import  copy#浅拷贝copy.copy()#深拷贝copy.deepcopy()#赋值 = 2.   对于数字和字符串而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个 ...

  2. python——赋值与深浅拷贝

    初学编程的小伙伴都会对于深浅拷贝的用法有些疑问,今天我们就结合python变量存储的特性从内存的角度来谈一谈赋值和深浅拷贝~~~ 预备知识一——python的变量及其存储 在详细的了解python中赋 ...

  3. Python中的深浅拷贝

    1.什么是深浅拷贝? python中一切皆对象,python中的数字.字符串.元组等,如果存放在了内存中,这部分内存里面的内容是不会改变的,但是也有情况,内存中存放了可变对象,比如说列表和字典,他们的 ...

  4. Python-Day3知识点——深浅拷贝、函数基本定义、内置函数

    一.深浅拷贝 import copy #浅拷贝 n1={'k1':'wu','k2':123,'k3':['carl',852]} n2=n1 n3=copy.copy(n1) print(id(n1 ...

  5. python基础知识5——赋值与深浅拷贝——整数和字符串,列表元组字典

    深浅copy 一.数字和字符串 对于 数字 和 字符串 而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址. 1 import copy 2 # ######### 数字.字符串 #### ...

  6. python 学习笔记5(深浅拷贝与集合)

    拷贝 我们已经详细了解了变量赋值的过程.对于复杂的数据结构来说,赋值就等于完全共享了资源,一个值的改变会完全被另一个值共享. 然而有的时候,我们偏偏需要将一份数据的原始内容保留一份,再去处理数据,这个 ...

  7. Python开发【第二章】:Python深浅拷贝剖析

    Python深浅拷贝剖析 Python中,对象的赋值,拷贝(深/浅拷贝)之间是有差异的,如果使用的时候不注意,就可能产生意外的结果. 下面本文就通过简单的例子介绍一下这些概念之间的差别. 一.对象赋值 ...

  8. python基础(三元运算+深浅拷贝+函数参数)

    三元运算 三元运算,又称三目运算,主要作用是减少代码量,是对简单的条件语句的缩写. 书写格式: result = 值1 if 条件 else 值2 即如果条件成立,则将值1赋给result变量,如果不 ...

  9. @proprety数组字典字符串用copy和strong区别(深浅拷贝)

    ////  @proprety数组字典字符串用copy和strong区别(深浅拷贝).h//  IOS笔记//// /* _proprety________copy_strong_________h ...

随机推荐

  1. 阶段1 语言基础+高级_1-3-Java语言高级_04-集合_03 斗地主案例(单列)_1_斗地主案例的需求分析

    洗牌用到集合工具类.Collections里面有个shuffle的方法 完整的需求分析

  2. spring boot gateway自定义限流

    参考:https://blog.csdn.net/ErickPang/article/details/84680132 采用自带默认网关请参照微服务架构spring cloud - gateway网关 ...

  3. Bootstrap 学习笔记 项目实战 首页内容介绍 下

    最终效果: HTML代码 <!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset ...

  4. Pku2054 Color a Tree

    有一个N个结点的有根树,1是这个树的根.现在要对这N个结点依次进行染色,每个结点染色要花费1个单位的时候,同时要满足一个结点仅在其父亲被染色后才可被染色,每个结点有个权值Ci,如果我们在第Ti时间对i ...

  5. YOLOV3中Darknet中cfg文件说明和理解

    今天将要说明的是Darknet中的cfg文件,废话少说,直接干!(以cfg/yolov3.cfg为例,其它类似) [net]                        ★ [xxx]开始的行表示网 ...

  6. 如何选择适合自己的Linux版本

    如何选择适合自己的Linux版本: 1.Linux桌面系统,首选Ubuntu; 2.服务器端的Linux系统,首选RHEL或CentOS,这两种中首选CentOS,如果公司有钱,不在乎成本也可以选择R ...

  7. [BZOJ 2301] [HAOI 2011] Problem b (莫比乌斯反演)(有证明)

    [BZOJ 2301] [HAOI 2011] Problem b (莫比乌斯反演)(有证明) 题面 T组询问,每次给出a,b,c,d,k,求\(\sum _{i=a}^b\sum _{j=c}^d[ ...

  8. timeout使用实例

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. 使用JS提交表单

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  10. 加密模块hashlib

    #coding=utf-8 import ConfigParser #配置文件模块 import hashlib #用于加密的模块 m = hashlib.md5() m.update(b'hello ...