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)

# 为什么要有深浅拷贝
# 拷贝比创建对象的过程要快

  

原文地址:https://www.cnblogs.com/duanpengpeng/p/9289040.html