1、补充

  1.1  join()字符串拼接.

 strs = "阿妹哦你是我的丫个哩个啷"
nw_strs = "_".join(strs)
print(nw_strs) # 阿_妹_哦_你_是_我_的_丫_个_哩_个_啷 lst = ["a","b","c","d"]
nw_lst = "*".join(lst)
print(nw_lst) # a*b*c*d

join()拼接

  1.2  不用clear()清空列表或字典 ----> 把要删除的元素放在新列表里,然后批量删除.

    list: 在循环遍历时每次删除都会导致列表内部元素的位置前移发生变化.

   dict: 在循环遍历时不允许变更字典的长度(即不能增加或删除键值对).

 li = [11, 22, 33, 44, 55]
while li:
li.pop()
print(li) # 只要li不为空就一直删除最后一个,直到为空 del_li = []
for i in li:
del_li.append(i)
for j in del_li: # 把要删除的元素放在另一个列表里,然后循环遍历新列表,删除旧列表
li.remove(j)
print(del_li)

清空列表

  1.3  fromkeys(参1,参2)

    创建新字典. 参1 为可迭代对象, 把参1 中的每一个元素作为key, 把参2 作为value, 生成新字典.

    fromkeys()是一个静态方法,只能通过类名或字典对象来调用, 返回的是一个新字典, 和原来的字典没有关系.

 d = dict.fromkeys("ab", [1,2,3])
print(d) # {'a': [1, 2, 3], 'b': [1, 2, 3]} dic = {"a":1}
d = dic.fromkeys("ab", [1,2,3])
print(d) # {'a': [1, 2, 3], 'b': [1, 2, 3]}

fromkeys()方法

2、set集合

  2.1  集合本身是不可哈希(可变)的, 但是里面的元素是不可变的, 而且是不能重复的.

    集合最大的作用就是去重.

 lst = [1,2,5,3,2,5,4,1]
print(list(set(lst))) # [1, 2, 3, 4, 5]

set去重

  2.2  增删改查

    增   add(),update()

 sets = {"王祖贤","张曼玉","关之琳"}
sets.add("刘嘉玲")
print(sets) #{'关之琳', '刘嘉玲', '张曼玉', '王祖贤'} sets.update(["张敏","刘嘉玲"])
print(sets) # {'刘嘉玲', '关之琳', '王祖贤', '张敏', '张曼玉'}

    删  remove(指定内容),    pop()不能指定

    改  集合是无序的,没有办法通过索引进行修改,只能先删除后添加.

    查  for循环遍历.

  2.3  交集(&), 并集(|), 差集(-), 反交集(^)

    s1 < or > s2    s1是s2的子集吗? ---->True or False

 s1 = {1,2,5,6,3,4,7}
s2 = {2,6,4,8,12,29}
print(s1 & s2) # {2, 4, 6}
print(s1 | s2) # {1, 2, 3, 4, 5, 6, 7, 8, 12, 29}
print(s1 - s2) # {1, 3, 5, 7} s1中单独存在的
print(s1 ^ s2) # {1, 3, 5, 7, 8, 12, 29} 两个集合中单独存在的数据

3、深浅拷贝

  = 赋值

    lst2 = lst1    将lst1的内存地址 赋值给lst2, 所以lst1 增删改,lst2 也发生变化

 lst1 = ["大魔王","二魔王","大老三","刘老四"]
lst2 = lst1 # 将lst1的内存地址赋值给lst2,所以lst1增删改,lst2也发生变化
lst1.append("王老五")
print(lst1)
print(lst2)

  浅拷贝  [:] 和 copy()----> 省内存.

    只复制第一层的内存地址.

 lst1 = ["大魔王","二魔王","大老三","刘老四"]
lst2 = lst1[:] # 只复制第一层的内存地址
lst1.append("王老五")
print(lst1) # ['大魔王', '二魔王', '大老三', '刘老四', '王老五']
print(lst2) # ['大魔王', '二魔王', '大老三', '刘老四'] lst1 = ["大魔王","二魔王",["大","老","三"],"刘老四"]
lst2 = lst1.copy() # 只复制第一层的内存地址,lst1和lst2引用的都是["大","老","三"]的内存地址,
# 不是里面元素,所以在["大","老","三"]发生增删改时,lst1和lst2也发生
变化.
lst1[2].append("不老")
print(lst1) # ['大魔王', '二魔王', ['大', '老', '三', '不老'], '刘老四']
print(lst2) # ['大魔王', '二魔王', ['大', '老', '三', '不老'], '刘老四']

浅拷贝

  深拷贝  deepcopy()  ---->占内存

    复制一个对象,里面有lst1的所有的元素, lst1的增删改和lst2 再无任何瓜葛.

 import copy
lst1 = ["大魔王","二魔王",["大","老","三"],"刘老四"]
lst2 = copy.deepcopy(lst1) # 深拷贝,把所有元素都copy过来,和lst2完全脱离,lst1的增删改和lst2无任何关系.
lst1[2].append("不老")
print(lst1) # ['大魔王', '二魔王', ['大', '老', '三', '不老'], '刘老四']
print(lst2) # ['大魔王', '二魔王', ['大', '老', '三'], '刘老四']

深拷贝

  

python摸爬滚打之day07----基本数据类型补充, 集合, 深浅拷贝的更多相关文章

  1. Day7--Python--基础数据类型补充,集合,深浅拷贝

    一.基础数据类型补充 1.join() 把列表中的每一项(必须是字符串)用字符串拼接 与split()相反 lst = ["汪峰", "吴君如", " ...

  2. Python基础知识(六)------小数据池,集合,深浅拷贝

    Python基础知识(六)------小数据池,集合,深浅拷贝 一丶小数据池 什么是小数据池: ​ 小数据池就是python中一种提高效率的方式,固定数据类型使用同一个内存地址 代码块 : ​ 一个文 ...

  3. python基础(9):基本数据类型四(set集合)、基础数据类型补充、深浅拷贝

    1. 基础数据类型补充 li = ["李嘉诚", "麻花藤", "⻩海峰", "刘嘉玲"] s = "_&qu ...

  4. Python基础数据类型补充及深浅拷贝

    本节主要内容:1. 基础数据类型补充2. set集合3. 深浅拷贝主要内容:一. 基础数据类型补充首先关于int和str在之前的学习中已经讲了80%以上了. 所以剩下的自己看一看就可以了.我们补充给一 ...

  5. is,数据类型补充,set,深浅拷贝

    十二.基础数据类型补充: 1.join 可以把列表变成字符串. s = ‘abc’ s1 = s.join(‘非常可乐’) print(s1)  #非abc常abc可abc乐abc s = " ...

  6. Python学习---列表/元组/字典/字符串/set集合/深浅拷贝1207【all】

    1.列表 2.元组 3.字典 4.字符串 5.set集合 6.深浅拷贝

  7. python学习打卡 day07 set集合,深浅拷贝以及部分知识点补充

    本节的主要内容: 基础数据类型补充 set集合 深浅拷贝 主要内容: 一.基础数据类型补充 字符串: li = ["李嘉诚", "麻花藤", "⻩海峰 ...

  8. 基本数据类型补充,set集合,深浅拷贝等

    1.join:将字符串,列表,用指定的字符连接,也可以用空去连接,这样就可以把列表变成str ll = ["wang","jian","wei&quo ...

  9. 6.Python初窥门径(小数据池,集合,深浅拷贝)

    Python(小数据池,集合,深浅拷贝) 一.小数据池 什么是小数据池 小数据池就是python中一种提高效率的方式,固定数据类型,使用同一个内存地址 小数据池 is和==的区别 == 判断等号俩边的 ...

随机推荐

  1. C++ 成员函数赋值给C 的函数指针的采坑录

    最近做一个banana Pi M1+的硬解码器封装成类的时候,由于是依赖ffmpeg的,而ffmpeg是C 实现的,本来demo 都是直接用C写的,测试也没有问题,想着封装也不会有问题,至少自己对C+ ...

  2. fresco xml配置属性不起作用

    在xml中配置加载等待图标,不起作用. 正确的如下: <?xml version="1.0" encoding="utf-8"?> <Line ...

  3. osx 10.11 一键制作U盘傻瓜工具最新版 无需任何命令

    osx 10.11 最新版U盘制作工具   无需任何命令   纯傻瓜式  !!!只要把app下载下来放在应用程序  鼠标点点就可以做了... 下载地址:http://diskmakerx.com/do ...

  4. python socket 实现的简单http服务器

    预备知识: 关于http 协议的基础请参考这里. 关于socket 基础函数请参考这里. 关于python 网络编程基础请参考这里. 一.python socket 实现的简单http服务器   废话 ...

  5. .net运行时dll的查找路径顺序

    D:\项目路径\.target\项目名.BLL.pdb”.已完成生成项目“D:\项目路径\项目名.BLL\项目名.BLL.csproj”(默认目标)的操作.ResolveAssemblyReferen ...

  6. ResDepot CRC码

    参考: 百度百科 crc校验 百度百科 crc编码 生日悖论 CRC32能不能用于检验文件的相同性 Egret RES版本控制 一.Egret的ResDepot在发布时,可以添加crc码. 发布前 发 ...

  7. Django----djagorest-framwork源码剖析

    restful(表者征状态转移,面向资源编程)------------------------------------------->约定 从资源的角度审视整个网络,将分布在网络中某个节点的资源 ...

  8. easyui---form表单_validatebox验证框

    第一种方式:混合写法 $("#password").validatebox({ }) <td><input type="text" name= ...

  9. d4

    # s = '132a4b5c'# s1 = s[0]+s[2]+s[1]# print(s1)#使用while和for循环分别打印字符串s=’asdfer’中每个元素.s = 'fkld'# for ...

  10. informix数据库触发器的写法

    虽然有各种数据库,但触发器的原理都是一样的,懂一种数据库的写法就可以了解其他的. 以前写过mysql数据库的触发器,这次写informix的,还顺带看了oracle的,除了语法上的不同,informi ...