• set集合,深浅拷贝


    1. 补充基础数据类型的相关知识点
      1. str. join() 把列表变成字符串

    s = "abc"
    s1 = s.join("非常可乐") # 把字符串s插入到"非常可乐"中
    print(s1)   #非abc常abc可abc乐
    
    
    s = "tx".join("sb")
    print(s)  #stxb
    
    
    s = "_".join(["alex", "wuse", "taibai", "ritian"])  # join可以把列表变成字符串, 把字符串变成列表.split()
    print(s)    #alex_wuse_taibai_ritian
    
    s = "sb".join(["王者荣耀", "LOL", "跑跑卡丁车"])
    print(s)
    

      


      2. 列表不能再循环的时候删除. 因为索引会跟着改变
      3. 字典也不能直接循环删除.
      把要删除的内容记录在列表中. 循环列表. 删除原列表, 字典中的数据

      

    lst = ["我不是药神", "西游记", "西红柿首富", "天龙八部"]
     
    # lst.clear()
    # list在循环的时候不能删. 因为会改变索引
    del_lst = []
    for el in lst:
        del_lst.append(el)  # 记录下来要删除的内容
     
    for el in del_lst:  # 循环记录的内容
        lst.remove(el)  # 删除原来的内容
    print(lst)
     
    lst = ["周杰伦", "周润发", "周星星", "马化腾", "周树人"]
    删除掉姓周的人的信息
    del_lst = []
    for el in lst:
        if el.startswith("周"):
            del_lst.append(el)
     
    for el in del_lst:
        lst.remove(el)
    print(lst)
     
    字典也不能在循环的时候更改大小
    dic = {"a":"123", "b":"456"}
    for k in dic:
        dic.setdefault("c", "123")
    

      


      4. fromkeys() 不会对原来的字典产生影响. 产生新字典(神坑, 考试)

    a = dict.fromkeys(["jj", 'jay', 'taibai'], "sb")  # 静态方法
    
    
    dic = {"a":"123"}
    s = dic.fromkeys("王健林", "思聪" ) # 返回给你一个新字典
    print(s)
    print(dic)  #输出原字典
    

      


      5. set集合. 不重复, 无序.

    s = set() # 空集合
    dic = dict()
    s = str()
    i = int()
    lst = list()
    print(i)
    
    s = {"王者荣耀", "英雄联盟", "王者荣耀", 123, True, True}
    print(s)
    s = {123, {1,2,3}}    # 不合法
    print(s)
    
    lst = ["张强", "李强", "王磊", "刘伟", "张伟", "张伟", "刘洋", "刘洋"]
    s = set(lst)    # 去重复
    print(s)
    
    # 变回来
    lst = list(s)
    print(lst)
    
    
    冻结了的set集合. 可哈希的. 不可变
    s = frozenset([1, 3, 6, 6, 9, 8])   # 可以去重复. 也是set集合
    print(s)
    
    ss = {"a", s}
    print(ss)
    

      


      6. 想转换成什么.就用什么括起来
      7. 深浅拷贝
        1. 直接赋值. 两个变量指向同一个对象.
        2. 浅拷贝:只拷贝第一层内容. copy()
        3. 深度拷贝: 对象中的所有内容都会被拷贝一份
        import copy
        copy.deepcopy()

    lst1 = ["金毛狮王", "紫衫龙王", "白眉鹰王", "青衣服往"]
    lst2 = lst1 # 列表, 进行赋值操作. 实际上是引用内存地址的赋值. 内存中此时只有一个列表. 两个变量指向一个列表
    
    lst2.append("杨做事")  # 对期中的一个进行操作. 两个都跟着变
    print(lst2)
    print(lst1)
    
    
    浅拷贝 copy 创建新对象
    lst1 = ["赵本山", "刘能", "赵四"]
    # lst2 = lst1.copy()  # lst2 和lst1 不是一个对象了
    lst2 = lst1[:]  # 切片会产生新的对象
    lst1.append("谢大脚")
    print(lst1, lst2)
    # print(id(lst1), id(lst2))
    
    
    lst1 = ["超人", "七龙珠", "葫芦娃", "山中小猎人", ["金城武", "王力宏", "渣渣辉"]]
    lst2 = lst1.copy()  # 拷贝. 浅拷贝 拷贝第一层
    
    lst1[4].append("大阳哥")
    
    print(lst1, lst2)
    深拷贝
    
    import copy
    lst1 = ["超人", "七龙珠", "葫芦娃", "山中小猎人", ["金城武", "王力宏", "渣渣辉"]]
    lst2 = copy.deepcopy(lst1)  # 把lst1扔进去进行深度拷贝 , 包括内部的所有内容进行拷贝
    lst1[4].append("大阳哥")
    print(lst1, lst2)
    
    # 为什么要有深浅拷贝
    # 拷贝比创建对象的过程要快
    

      

  • 相关阅读:
    Unity3d启动事件
    UI 科学
    LOL
    流光
    PlayerPrefs
    C++
    Android Home
    状态机
    架构设计
    AI
  • 原文地址:https://www.cnblogs.com/duanpengpeng/p/9289040.html
Copyright © 2020-2023  润新知