day8 列表相关函数、深浅拷贝、字典相关函数、集合相关操作和函数

列表的相关操作:拼接 重复 切片 索引 修改 删除
列表相关函数:增3+删3+其他4
列表拓展:深浅拷贝

字典相关函数:增1/1+删3+改1/1+查1+最重要3

集合相关操作:交集 差集 并集 对称差集 子集 父集
集合相关函数:操作7+增2+删4

# ### 列表相关的函数(增3+删3+其他4)

增  append、insert、extend

# append 向列表的末尾添加新的元素
lst.append("Jenny")
print(lst)

# insert 向指定索引之前插入元素
lst.insert(0,"Alan")
lst.insert(2,"Cat")
print(lst)

# extend 迭代追加所有元素
'''要求:数据的类型必须是可迭代性数据'''
strvar = "abcde"
lst.extend(strvar)
print(lst)

 

删  pop、remove、clear

# pop 通过指定索引删除元素,若没有索引则移除最后那个
lst=["Fly","Hurt","Cat","Alan","Yang"]
# 指定索引进行删除
res = lst.pop(1)
# 默认没有任何参数,删除的是最后一个
res = lst.pop()
print(res)
print(lst)

# remove 通过给予的值来删除,如果多个相同元素,默认删除第一个
lst=["Fly","Hurt","Cat","Alan","Yang"]
# 指定值进行删除,如果有多个相同的重复值,默认删掉第一个
lst.remove("Alan")
print(lst)

# clear 清空列表
lst=["Fly","Hurt","Cat","Alan","Yang"]
lst.clear()
print(lst)

 

其它  index、coun、sort、reverse

# 其他函数 index count sort reverse
lst=["Fly","Fly","Fly","Fly","Hurt","Cat","Alan","Yang"]

# index 获取某个值在列表中的索引
'''列表.index(值,[,start],[,end]) 表达参数可选项 找不到报错''' 
res = lst.index("Hurt")
res = lst.index("Hurt",3)
res = lst.index("Hurt",2,4)
print(res)

# count 计算某个元素出现的次数
res = lst.count("Fly")
print(res)
'''
注意:字符串里的count可以划定范围,列表里面的count不行
'''
strvar = "aaaaabcdefg"
res = strvar.count("a",1,6)
print(res)

# sort() 列表排序(默认小到大排序)
# 默认从小到大
lst=[3,8,26,9,-25,-1,7]
lst.sort()
# 从小到大排序
lst.sort(reverse=True)
print(lst)
# 排序英文------> ASCII编码
'''一位一位进行比较,在第一次相同的情况下,比较第二位,以此类推'''
lst=["Cow","Fly","Hurt","Cat","Alan","Yang"]
lst.sort()
print(lst)
# 也可以对中文排序-------> 但是无规律可循
lst = ["方法","非他","哥哥","4特特他","忒特他"]
lst.sort()
print(lst)

# reverse() 列表反转操作
lst = ["替换的","个人股","但如果","合同号","额二天"]
lst.reverse()
print(lst)

 

# ### 深浅拷贝

(1)浅拷贝只拷贝一级容器中的所有数据

(2)深拷贝拷贝所有层级的所有元素
浅拷贝速度比深拷贝速度快
深拷贝在执行时: 如果是不可变数据,地址会暂时的指向原来数据,
如果是可变数据,直接开辟新空间
不可变数据: Number str tuple
可变数据 : list set dict

 1.浅拷贝

import copy
lst1=[1,2,3]
# 方法一:copy.copy 模块.方法
lst2 = copy.copy(lst1)
lst1.append(4)
print(lst1) #[1, 2, 3, 4]
print(lst2) #[1, 2, 3]
# 方法二:列表.copy()
lst1 = [1,2,3,4]
lst3 = lst1.copy()
lst1.insert(0,0)
print(lst1) # [0, 1, 2, 3, 4]
print(lst3) # [1, 2, 3, 4]

 

2.深拷贝

# 引入深拷贝(浅拷贝无法满足需求)
lst1 = [1,2,3,[4,5,6]]
lst2 = copy.copy(lst1)
lst1[-1].append(7)
lst1.append(100)
print(lst1) # [1, 2, 3, [4, 5, 6, 7], 100]
print(lst2) # [1, 2, 3, [4, 5, 6, 7]]

# deepcopy 深拷贝
lst1 = [1,2,3,[4,5,6]]
lst2 = copy.deepcopy(lst1)
# lst1[-1].extend("ab")
print(lst2) # [1,2,3,[4,5,6]]
print(lst1) # [1,2,3,[4,5,6]]

print(id(lst2[-1])) # 2731177062472
print(id(lst1[-1])) # 2731177036872

print(id(lst1[0])) # 1347321968
print(id(lst2[0])) # 1347321968

lst2[0] = 11
print(id(lst1[0])) # 1347321968
print(id(lst2[0])) # 2390383439568

  

# ### 字典相关函数(增1/1+删3+改1/1+查1+最重要3)

增  直接添加、fromkeys

dic = {}
dic["ww"] = "一表人才,除了帅气的皮囊之外,一无所有"
dic['ywz'] = "渣男"
dic["hxl"] = "抠脚老汉"
print(dic)

#fromkeys()  使用一组键和默认值创建字典
lst = ["ww","ywz","hxl"]
dic = {}.fromkeys(lst,None)
print(dic)

# 注意点: 三个键所指向的列表是同一个(不推荐)
"""
dic = {}.fromkeys(lst,[])
print(dic)
dic["ww"].append(1)
print(dic)


dic["ww"] = []
dic['ywz'] =[]
dic["hxl"] =[]
"""

 

删 pop、popitem、clear

#pop()	通过键去删除键值对 (若没有该键可设置默认值,预防报错)
dic = {"top":"花木兰" , "middle":"甄姬" , "bottom":"孙尚香" ,  "jungle" : "钟馗" , "support":"蔡文姬" }
res = dic.pop("top")
# 如果删除的是不存在的键,直接报错
res = dic.pop("top123")
# 可以设置默认值,防止报错
res = dic.pop("top123","没有这个键")
res = dic.pop("middle","没有这个键")
print(res , dic,"<=======>")

#popitem()	删除最后一个键值对 
res = dic.popitem()
print(res, dic)

#clear()	清空字典
dic.clear()
print(dic)

 

改 update

#update() 批量更新(有该键就更新,没该键就添加)
dic = {'ww': '一表人才,除了帅气的皮囊之外,一无所有', 'ywz': '渣男', 'hxl': '抠脚老汉'}
dic_new = {"ywz":"暖男","hxl":"扣手","ly":"小美女,单纯,可爱,活泼,灵巧...."}

# 方法一(推荐)
dic.update(dic_new)
print(dic)

# 方法二
dic.update(kxq="聪明,活泼,可爱,灵巧,惹人喜欢",ccg="乐观,大方,可爱,灵巧")
print(dic)

 

查  get、keys、values、items  

#get()    通过键获取值(若没有该键可设置默认值,预防报错)
dic = {'ww': '一表人才,除了帅气的皮囊之外,一无所有', 'ywz': '暖男', 'hxl': '扣手'}
res = dic.get("ww")
res = dic.get("zbcdefg") # None
res = dic.get("zbcdefg","没有这个键")
res = dic['abcee'] error
print(res)

#  重要 ***
dic = {'ww': '一表人才,除了帅气的皮囊之外,一无所有', 'ywz': '暖男', 'hxl': '扣手'}
#keys()   将字典的键组成新的可迭代对象
res = dic.keys()
print(res)

#values() 将字典中的值组成新的可迭代对象
res = dic.values()
print(res)

#items()  将字典的键值对凑成一个个元组,组成新的可迭代对象 
res = dic.items()
print(res)

 

# ### 集合的相关操作

intersaction() 交集、difference() 差集、union() 并集、symmetric_difference() 对称差集 (补集情况涵盖在其中)、issubset() 判断是否是子集、issuperset() 判断是否是父集

 

set1={"a","b","c","d"}
set2={"15sui","SK","Dgc","Cat"}

# intersaction() 交集
res = set1.intersaction(set2)
print(res)
# 交集简写 & 
res = sey1 & set2
print(res)

#difference() 差集  
res = set1.difference(set2)
print(res)
# 差集简写 -
res = set1 - set2
print(res)

#union() 并集     
res = set1.union(set2)
print(res)
# 简写 |
res = set1 | set2
print(res)

#symmetric_difference() 对称差集 (补集情况涵盖在其中) 
res = set1.symmetric_difference(set2)
print(res)
# 简写 ^
res = set1 ^ set2
print(res)

#issubset() 判断是否是子集
set1 = {"Fly","JieJ","Nuoyan","Orange"}
set2 = {"Fly","JieJ"}
res = set1.issubset(set2)
print(res)
# 简写 < 
res = set1 < set2
print(res)

#issuperset() 判断是否是父集
res = set1.issuperset(set2)
print(res)
# 简写 > 
res = set1 > set2
print(res)

#isdisjoint() 检测两集合是否不相交  不相交为True  相交为False
res = set1.isdisjoint(set2)
print(res)

 

# ### 集合的相关函数(增2+删4)

增  add、update

# add() 向集合中添加数据(一次加一个)
setvar.add("Djie")
print(setvar)

# update() 迭代着增加 (一次加一堆)
strvar = ("Ache","Yuyu")
setvar.update(strvar)
print(setvar)

 

删  clear、pop、remove、discard

set2 = {"Fly","JieJ","Rxy"}

# clear() 清空集合
set2.clear()

# pop() 随机删除集合中的一个数据
res = set2.pop()
print(res,set2)

# remove() 删除集合中指定的值(不存在则报错)(了解)
setvar.remove("Fly")
print(setvar)

# discard() 删除集合中指定的值(不存在的不删除)(推荐使用)
set2.discard("Fly")
set2.discard("Sehah")
print(set2)

 

# ### 冰冻集合 frozenset

frozenset 可强转容器类型数据变为冰冻集合

lst1 = ["Fly","Mojo","Hurt","770"]
fz1 = frozenset(lst1)
lst2 = ("Amy","Mike","Lucy")
fz2 = frozenset(lst2)
print(fz1 , type(fz1))
print(fz2 , type(fz2))

# 不能够在冰冻集合当中添加或者删除元素
fz1.add("Marry") # error
# 只能交差并补 print(fz1 & fz2) print(fz1 - fz2)

  

 

 

posted @ 2020-07-20 11:50  liyaaa  阅读(87)  评论(0编辑  收藏  举报