day07 python
 
一.知识点补充
    1."".join()
s = "".join(('1','2','3','4','5'))  #将字符串类型的可迭代的类型的每个元素按""引号中的东西拼接成字符串
print(s)
    
    2.list 的for循环删元素的问题
lst = [1,2,3,4]
 
for i in lst:
    lst.remove(i)
print(lst)
>>>[2, 4]            #剩两个元素, 是因为有个变量来记录当前循环的位置, 
    
    如何解决
lst = [1,2,3,4]
lst1 = lst[:]       #循环新列表, 取出来的元素用来删老列表
 
for i in lst1:
    lst.remove(i)
print(lst)
  
    3.dict 在for 循环时不能改变大小, 但可以改value的值
dic = {1:1,2:2,3:3,4:4,5:5}
 
for i in dic:
    dic.pop(i)
 
print(dic)
>>>RuntimeError: dictionary changed size during iteration    #运行时错误, 不能删除, 也不能增加
    
    如何解决
dic = {1:1,2:2,3:3,4:4,5:5}
lst=[]
 
for i in dic:
    lst.append(i)
 
for i in lst:
    dic.pop(i)
 
print(dic)            #与列表一样, 循环新的, 删老的
  
    4.{}.fromkeys()
dic = {1:1,2:2,3:3,4:4,5:5}
 
ret = dic.fromkeys('bajie', 'datang')   #返回新的字典, 和原来的字典没有关系
 
ret1 = dict.fromkeys('abc', '666')      #直接使用类名进行访问
 
print(dic)
>>>{1: 1, 2: 2, 3: 3, 4: 4, 5: 5}
print(ret)
>>>{'b': 'datang', 'a': 'datang', 'j': 'datang', 'i': 'datang', 'e': 'datang'}
print(ret1)
>>>{'a': '666', 'b': '666', 'c': '666'}
    
    里面的列表是共享的
lst = [1,2,3,4,5]
ret = dict.fromkeys('abc', lst)
lst.append(6)
 
print(ret)
>>>{'a': [1, 2, 3, 4, 5, 6], 'b': [1, 2, 3, 4, 5, 6], 'c': [1, 2, 3, 4, 5, 6]}    #所有人用的是同一个列表(判断是不是一个内存地址)
 
二.集合
 
    1.set() , 不重复, 无序的, 里面的元素必须是可哈希的(不可变): 就是没有value的字典, 也用{}表示: 集合本身是可变的, 不可哈希
lst = [1,2,2,3,4,5,6,45,345,3,2,3,2,3,23,4,432,342,4]
lst = list(set(lst))
print(lst)      #去重用集合, 很好用
    2.增删改查(了解:用的时候回来看)
 
        增
s = {1,2,3,4,5,6}
s.add()    #增加一个元素
s.update('bajie')   #迭代增加
print(s)
        删  
print(s.pop())      #随机弹出一个, 有返回值, 返回被弹出的元素
print(s)
 
s.remove(1)     #删一个元素
 
s.clear()       #清空
        改
s.remove(2)     #先删掉
s.add(6)        #再添加
        查
for i in s:     #可用 for 循环
    print(i)
    
    3.集合的其他操作
        交集
s1 = {1,2,3}
s2 = {2,3,4}
 
print(s1 & s2)
print(s1.intersection(s2))
        并集
print(s1 | s2)
print(s1.union(s2))
        差集
print(s1 - s2)
print(s1.difference(s2))    #得到第一个中单独存在的
        反交集
print(s1 ^ s2)
print(s1.symmetric_difference(s2))    #两个集合单独存在的数据
        子集
print(s1 < s2)
print(s1.issubset(s2))
        超集
print(s1 > s2)
print(s1.issubset(s2))
 
  
    4.frozenset() 是不可变的集合, 是可哈希的
 
    5.哈希算法: 只要得到的结果是数字, 就认为是哈希算法
 
三.深浅拷贝
    1.赋值拷贝:内存地址都相同
lst1 = [1,2,3,4,5,6]
lst2 = lst1                     #赋值操作时, 内存的地址相同(有嵌套时, 第二层内存地址也相同)
lst1.append(7)
print(id(lst1),id(lst2))
    
    2.浅拷贝:第一层内存地址相同, 第二层不同
lst2 = lst1[:]                  #浅拷贝,方式一
print(id(lst1),id(lst2))        #用切片取出来再赋值操作时, 内存地址就变了
 
lst2 = lst1.copy()              #浅拷贝,方式二
print(id(lst1),id(lst2))        #内存地址不一样
 
lst1 = [1,2,3,4,5,6,[1,2,3,4,5,6]]      #浅拷贝, 当有嵌套时, 只有第一层拷贝了, 第二层还是共用数据
lst2 = lst1.copy()
print(id(lst1[6]))                      #第二层嵌套的内存地址相同
print(id(lst2[6]))
    
    3.深拷贝:第一层和第二层内存地址都不同
import copy
 
lst2 = copy.deepcopy(lst1)          #深拷贝, 当有嵌套时, 所有层次都会拷贝
print(id(lst1[6]))                  #第二层嵌套的内存地址也变了
print(id(lst2[6]))
 
  
练习
 
cars = ['京A34567','冀R44566', '京A55899','冀R44566','冀R44566']
locals = {'京':'北京','冀':'河北省'}
rst = {}
 
for i in cars:
    location  = locals[i[0]]
    if not rst.get(location):
        rst[location] = 1
    else:
        rst[location] += 1
print(rst)
 
>>>{'北京': 2, '河北省': 3}
 
 
 
 
 
 

day07 python列表 集合 深浅拷贝的更多相关文章

  1. day8 python学习 集合 深浅拷贝

    1.内存地址: 字符串在20位以内,没有空格,没有特殊字符的情况下,同样的字符串内存地址是一样的 2.元组中:在只有一个值的时在后边加逗号和没有逗号的区别 t1=(1) 不加逗号这个值是什么类型就打印 ...

  2. python学习打卡 day07 set集合,深浅拷贝以及部分知识点补充

    本节的主要内容: 基础数据类型补充 set集合 深浅拷贝 主要内容: 一.基础数据类型补充 字符串: li = ["李嘉诚", "麻花藤", "⻩海峰 ...

  3. 6.Python初窥门径(小数据池,集合,深浅拷贝)

    Python(小数据池,集合,深浅拷贝) 一.小数据池 什么是小数据池 小数据池就是python中一种提高效率的方式,固定数据类型,使用同一个内存地址 小数据池 is和==的区别 == 判断等号俩边的 ...

  4. join,列表和字典用for循环的删除,集合,深浅拷贝

    1.join() 将列表转换成字符串,并且每个字符之间用另一个字符连接起来,join后面必须是可迭代的对象(字符串,列表,元组,字典,集合),数字不能迭代 例如: s = ['a','b','c'] ...

  5. Python基础知识(六)------小数据池,集合,深浅拷贝

    Python基础知识(六)------小数据池,集合,深浅拷贝 一丶小数据池 什么是小数据池: ​ 小数据池就是python中一种提高效率的方式,固定数据类型使用同一个内存地址 代码块 : ​ 一个文 ...

  6. 第五篇python进阶之深浅拷贝

    目录 第五篇python进阶之深浅拷贝 一.引言 1.1可变 和不可变 二.拷贝(只针对可变数据类型) 三.浅拷贝 四.深拷贝 第五篇python进阶之深浅拷贝 一.引言 1.1可变 和不可变 id不 ...

  7. 天啦噜!仅仅5张图,彻底搞懂Python中的深浅拷贝

    Python中的深浅拷贝 在讲深浅拷贝之前,我们先重温一下 is 和==的区别. 在判断对象是否相等比较的时候我们可以用is 和 == is:比较两个对象的引用是否相同,即 它们的id 是否一样 == ...

  8. Python 中的深浅拷贝

    Python 中的深浅拷贝 参考文献:https://blog.csdn.net/lnotime/article/details/81194633 参考文献:https://blog.csdn.net ...

  9. Python学习---列表/元组/字典/字符串/set集合/深浅拷贝1207【all】

    1.列表 2.元组 3.字典 4.字符串 5.set集合 6.深浅拷贝

随机推荐

  1. oracle trim无效?

    这里说说如果是全角空格怎么去除 方法一 trim(TO_SINGLE_BYTE('aaa')) 方法二 SELECT TRIM(replace('aaa',' ','')) FROM dual

  2. 16.ThreadGroup线程组

    public class ThreadGroupDemo implements Runnable{ public static void main(String[] args){ //建立一个名为&q ...

  3. Hadoop(一)阿里云hadoop集群配置

    集群配置 三台ECS云服务器 配置步骤 1.准备工作 1.1 创建/bigdata目录 mkdir /bigdatacd /bigdatamkdir /app 1.2修改主机名为node01.node ...

  4. vue登录页和主页路由配置问题

    登录页和主菜单首页是同一级的,都是用一个router-view,对于home页面里还有菜单,这里边还可以再增加一个router-view,那么在配置时候就是在home的路径增加个children路径配 ...

  5. LR快捷键

    record optioning:录制选项——ctrl+f7 runtime setting  : 运行时设置——F4 运行脚本——F5 参数列表:ctrl+L 注释:ctrl+shift+c 选中后 ...

  6. ldap yum安装-centos6

    yum安装openldap 系统环境信息 操作系统:CentOS release 6.7 基础的环境准备 iptables -F && /etc/init.d/iptables sav ...

  7. cookie的使用说明

    cookie的英文意思是饼干的意思,实质上是键值对组成的字典.就是说你访问某一个网址,服务器给你一个东西,你收到东西,并且贴上了一个标签.下次你访问服务器的时候,请求带有标签.这样服务器给你之后,就会 ...

  8. js千位符 | js 千位分隔符 | js 金额格式化

    js 千位分隔符 千位分隔符,其实就是数字中的逗号.依西方的习惯,人们在数字中加进一个符号,以免因数字位数太多而难以看出它的值.所以人们在数字中,每隔三位数加进一个逗号,也就是千位分隔符,以便更加容易 ...

  9. Spring MVC请求参数绑定 自定义类型转化 和获取原声带额servlet request response信息

    首先还在我们的框架的基础上建立文件 在domian下建立Account实体类 import org.springframework.stereotype.Controller; import org. ...

  10. Nginx网络架构实战学习笔记(一):Nginx简介、安装、信号控制、nginx虚拟主机配置、日志管理、location 语法、Rewrite语法详解

    文章目录 nginx简介 nginx安装 nginx信号控制 nginx虚拟主机配置 日志管理 location 语法 精准匹配的一般匹配 正则匹配 总结 Rewrite语法详解 nginx简介 Ng ...