小数据池

  1. int: -5~256
  2. str:
    1. 字母,数字长度任意符合驻留机制
    2. 字符串进行乘法时总长度不能超过20
    3. 特殊符号进行乘法时只能乘以0

代码块:

一个py文件,一个函数,一个模块,终端中的每一行都是代码块

  1. int:-5~无穷大
  2. str:
    1. 定义字符串的时候可以是任意的
    2. 字符串(字母,数字)进行乘法时总长度不得超过20
    3. 特殊字符(中文,符号)进行乘法时乘以0或者1
  3. bool:
    1. True
    2. False

is是判断两边的内存地址是否相同

==判断两个值是否相等

代码块、小数据池同在的情况下先执行代码块。

驻留机制:节省内存空间,提升效率(减少了开辟空间和销毁空间的耗时)

集合

  1. 集合是python中的数据类型之一

  2. 定义方式:set

    • 集合就是一个没有值的字典
  3. 字典的值:唯一,不可变

  4. 集合:无序,可变

  5. 集合天然去重

    # s = {1,23,4,2,1,2,3,1}
    print(s)
    输出结果:{1, 2, 3, 4, 23}
    # 面试题:
    lst = [1,223,1,1,2,31,231,22,12,3,14,12,3] print(list(set(lst)))
    输出结果:[1, 2, 223, 3, 231, 12, 14, 22, 31]
  6. s = {} #空字典

    s = set() #空集合

  7. 增:

     s = set()    
    
    s.add("alex")   #直接添加,
    
    输出结果为:{'alex'}    
    
     s.update("wusir")   #迭代添加,
    
    输出结果为:{'r', 'i', 'w', 's', 'u'}    
    
     set("wusir")    #迭代添加,
    
    输出结果为:set()
  8. s = {100,0.1,0.5,1,2,23,5,4}
    s.remove(4) # 通过元素删除
    print(s)
    s.clear() # 清空
    s.pop() # 随机删除 (最小的)
    print(s)
  9. 改:

    • 先删后加
  10. 查:

    • for 循环
  11. 其他操作:

    1. 差集--“-”
    2. 交集--“&”
    3. 并集--“|”-管道符
    4. 反交集--“^”
    5. 子集--“>”返回的是一个布尔值
    6. 父集(超集)--"<"返回的是一个布尔值
    7. 冻结集合:frozenset()

深浅拷贝

  1. ​ 赋值:将多个变量指向一个同一个内存地址就是赋值

  2. 浅拷贝:

    1. 只拷贝第一层元素的地址,只有修改第一层的时候元数据不受影响

    2. 给可变数据类型进行添加的时候源数据会受影响

    3. = 是修改,.append是添加

    4. 可变数据类型能够添加和修改,不可变数据类型只能修改

      a = [1,2,3,[4,5]]
      b = a[:] # 浅拷贝
      print(id(a[-1][0]))
      print(id(b[-1][0]))
      a.append(9)
      print(a)
      print(b)
      a = [1,2,3,[4,5,6,[9,10]],67]
      b = a # 赋值
      b = a[:]
      a[-2].append(10)#[1, 2, 3, [4, 5, 6, [9, 10], 10], 67]
      a[-2][-1].append(10)#[1, 2, 3, [4, 5, 6, [9, 10, 10]], 67]
      print(b)
  3. 深拷贝:不可变数据类型内存地址共用,可变数据类型新开辟一个空间

    # import copy  # 导入 copy模块
    a = [1,2,3,[4,5],6]
    b = copy.deepcopy(a)
    print(id(a[-2]))#2812949845896
    print(id(b[-2]))#2812949847304
    print(a)
    print(b)
    print(a == b) #True
    print(id(a),id(b))
    print(a is b) #False

可变数据类型:list(列表),dict(字典),set(集合)

不可变数据类型:int(整型),str(字符串),tuple(元祖),bool(布尔值)

从入门到自闭之Python集合,深浅拷贝(大坑)的更多相关文章

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

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

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

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

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

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

  4. Python原理 -- 深浅拷贝

    python原理 -- 深浅拷贝 从数据类型说开去 str, num : 一次性创建, 不能被修改, 修改即是再创建. list,tuple,dict,set : 链表,当前元素记录, 下一个元素的位 ...

  5. Python的深浅拷贝

    Python的深浅拷贝 深浅拷贝 1. 赋值,对于list, set, dict来说, 直接赋值. 其实是把内存地址交给变量并不是复制一份内容 list1 = [']] list2 = list1 p ...

  6. 从入门到自闭之python初识

    Day 01 整型: 对比: 在python 2 版本中有整型,长整型long 在python 3 版本中全部都是整型 用于计算和比较 整型和布尔值的转换 二进制转换成十进制: ​print (int ...

  7. day07 python列表 集合 深浅拷贝

    day07 python   一.知识点补充     1."".join() s = "".join(('1','2','3','4','5'))  #将字符串 ...

  8. python摸爬滚打之day07----基本数据类型补充, 集合, 深浅拷贝

    1.补充 1.1  join()字符串拼接. strs = "阿妹哦你是我的丫个哩个啷" nw_strs = "_".join(strs) print(nw_s ...

  9. Python学习基础(二)——集合 深浅拷贝 函数

    集合 # 集合 ''' 集合是无序不重复的 ''' # 创建列表 l = list((1, 1, 1)) l1 = [1, 1, 1] print(l) print(l1) print("* ...

随机推荐

  1. CVE-2019-0708复现

    本人在此申明: 此次复现仅供学习使用 不可用于非法用途 一切违法后果与本人无关 复现0708第一步 github下载exp Kali里面执行命令 wget https://raw.githubuser ...

  2. [Java]使用Collections.Max,Min方法取集合类的最大最小值

    代码: package com.hy; import java.util.Arrays; import java.util.Collections; import java.util.List; pu ...

  3. display:flex 布局详解(2)

    1.  flex设置元素垂直居中对齐 在之前的一篇文章中记载过如何垂直居中对齐,方法有很多,但是在学习了flex布局之后,垂直居中更加容易实现 HTML代码: <div class=" ...

  4. 谈谈我对证券公司一些部门的理解(前、中、后台)[z]

    [z]https://blog.csdn.net/UniRong/article/details/79289947 文中对各大部门的分析都是从作者多年经历总结出来的有感之谈,尤其是前台的6大部门(经纪 ...

  5. 深度学习之NLP获取词向量

    1.代码 def clean_text(text, remove_stopwords=False): """ 数据清洗 """ text = ...

  6. haproxy-负载均衡介绍

    参考:http://www.iyunv.com/thread-252539-1-1.html 负载均衡介绍 四层和七层负载均衡的区别 四层 所谓的四层就是ISO参考模型中的第四层.四层负载均衡也称为四 ...

  7. java高级之多线程

    1.1,多线程的作用: *线程是程序执行的一条路径, 一个进程中可以包含多条线程 *多线程并发执行可以提高程序的效率, 可以同时完成多项工作 1.2,多线程的应用场景: * 红蜘蛛同时共享屏幕给多个电 ...

  8. selenium 常见操作事件2

    1.不打开浏览器驱动(加速) 注意:不启动浏览器器时,需要把浏览器驱动放置以下位置:①.python安装的根目录②.google的安装目录() from selenium import webdriv ...

  9. RTSP协议-中文定义

    RTSP协议-中文定义 转自:http://blog.csdn.net/arau_sh/article/details/2982914 E-mail:bryanj@163.com 译者: Bryan. ...

  10. vue3.x版本安装vue-cli建项目

    vue-cli版本在3以上 全局安装vue-cli npm install -g @vue/cli 建立项目工程,假设项目建在e:\vueProject\vue-cli3.0+目录下: 先进入此目录: ...