基础数据类型转换和深浅拷贝

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

      

 


2. 列表不能在循环的时候删除. 因为索引会跟着改变

      

 


3. 字典也不能直接循环删除.
把要删除的内容记录在列表中. 循环列表. 删除原列表, 字典中的数据
4. fromkeys() 不会对原来的字典产生影响. 产生新字典(神坑, 考试)
新字典中如果其中一个value值发生变化 所有的value都会变化 因为keys指向的都是一个内存地址
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)
set基本用法

 


6. 想转换成什么.就用什么括起来
元组 => 列表 list(tuple)
列表 => 元组 tuple(list)
list=>str str.join(list)
str=>list str.split()
转换成False的数据:
0,'',None,[],(),{},set() ==> False
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)

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

 

posted @ 2018-07-18 15:51  最后一个老实人  阅读(118)  评论(0编辑  收藏  举报
W3School 在线教程