博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
set集合,深浅拷贝
阅读量:5236 次
发布时间:2019-06-14

本文共 2338 字,大约阅读时间需要 7 分钟。

1. 补充基础数据类型的相关知识点

  1. str. join() 把列表变成字符串

s = "abc"s1 = s.join("非常可乐") # 把字符串s插入到"非常可乐"中print(s1)   #非abc常abc可abc乐s = "tx".join("sb")print(s)  #stxbs = "_".join(["alex", "wuse", "taibai", "ritian"])  # join可以把列表变成字符串, 把字符串变成列表.split()print(s)    #alex_wuse_taibai_ritians = "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 copylst1 = ["超人", "七龙珠", "葫芦娃", "山中小猎人", ["金城武", "王力宏", "渣渣辉"]]lst2 = copy.deepcopy(lst1)  # 把lst1扔进去进行深度拷贝 , 包括内部的所有内容进行拷贝lst1[4].append("大阳哥")print(lst1, lst2)# 为什么要有深浅拷贝# 拷贝比创建对象的过程要快

  

转载于:https://www.cnblogs.com/duanpengpeng/p/9289040.html

你可能感兴趣的文章
PHPStorm2017设置字体与设置浏览器访问
查看>>
SQL查询总结 - wanglei
查看>>
安装cocoa pods时出现Operation not permitted - /usr/bin/xcodeproj的问题
查看>>
GIT笔记:将项目发布到码云
查看>>
JavaScript:学习笔记(7)——VAR、LET、CONST三种变量声明的区别
查看>>
JavaScript 鸭子模型
查看>>
SQL Server 如何查询表定义的列和索引信息
查看>>
GCD 之线程死锁
查看>>
NoSQL数据库常见分类
查看>>
一题多解 之 Bat
查看>>
Java 内部类
查看>>
{面试题7: 使用两个队列实现一个栈}
查看>>
【练习】使用事务和锁定语句
查看>>
centos7升级firefox的flash插件
查看>>
Apache Common-IO 使用
查看>>
评价意见整合
查看>>
二、create-react-app自定义配置
查看>>
Android PullToRefreshExpandableListView的点击事件
查看>>
系统的横向结构(AOP)
查看>>
linux常用命令
查看>>