基础数据类型的补充
join() 把列表转化成字符串,是迭代的方式进行的拼接
lst = ["alex", "dsb", "wusir", "xsb"]
# 使用前面的字符串. 对后面的列表进行拼接,拼接的结果是一个字符串
s = "_".join(lst)
print(s) ###alex_dsb_wusir_xsb
split() 把字符串转化成列表
lst = 'alex$dsb$wusir$xsb'
s = lst.split('$')
print(s) ####['alex', 'dsb', 'wusir', 'xsb']
列表和字典都不能再循环的时候直接删除,要把删除的内容记录在新的列表中,然后在循环这个新列表,删除列表(字典)
最合理的删除方式:
1,把要删除的内容写在新列表中
2, 循环这个新列表,删除老列表
lst = ['篮球', '排球', '足球', '电子竞技', '台球']
new_lst = []
for i in lst:
if '球' in i:
new_lst.append(i)
for i in new_lst:
lst.remove(i)
print(lst)
关于删除的具体的讲解
st = ["篮球", "排球" ,"足球", "电子竞技", "台球"]
lst.clear()
for el in lst:
lst.remove(el)
print(lst) # 删不干净.原因是: 删除一个. 元素的索引要重新排列, for循环向后走一个. 差一个
for i in range(len(lst)): # 0 1 2 3 4
lst.pop(0)
print(lst) #[]
lst = ["篮球", "排球" ,"足球", "电子竞技", "台球"]
# 最合理的删除方式:
# 1. 把要删除的内容写在新列表中.
# 2. 循环这个新列表. 删除老列表
# 需求: 删除列表中代球字的运动项目
new_lst = []
for el in lst:
if "球" in el:
new_lst.append(el) # 记录要删除的内容
# 要删除的列表
print(new_lst)
# 循环新列表. 删除老列表
for el in new_lst: # ['篮球', '排球', '足球', '台球']
lst.remove(el)
print(lst)
字典
列表和字典在被循环的时候是不能删除的.
1,把要删除的key保存在一个新列表中,
2,循环这个列表.删除字典中的key:vlause
##### 坑: 大坑, 神坑 面试题:
fromkeys() 帮我们创建字典的, 把第一个参数进行迭代. 拿到每一项作为key和后面的value组合成字典
#坑1: 返回新字典,和原来的字典没有关系
dic = {}
d = dic.fromkeys('风扇哥', '很困') ###会新建一个字典
print(dic) #{}
#坑2: 如果value是可变的数据类型,那么其中的一个key对应value
d = dict.fromkeys('胡辣汤',[])
print(d) #{'胡': [], '辣': [], '汤': []}
d['胡'].append("河南特色") ### key 对应的是同一个列表,key变但是value不变
print(d) #{'胡': ['河南特色'], '辣': ['河南特色'], '汤': ['河南特色']}
深浅拷贝
1.= 没有创建新对象,只是把内存地址进行了复制
从上到下只有一个列表被创建
2.lst.copy 浅拷贝,只拷贝第一层
copy.deepcopy() 深拷贝,对象内部的所有内容都要进行拷贝. 深度克隆.原型模式
为什么要有深浅的拷贝?
提高创建对象的速度,计算中最慢的,就是创建对象,需要分配内存. 最快的方式就是二进制流的形式进行复制.速度最快.