07  set集合,深浅拷⻉以及部分知识点补充

一.while,for 循环知识点补充

二.int, str的相关操作

1.列表变字符串
# lst=["红","橙","黄","绿","青","蓝","紫"]
  方法一

# s="_".join(lst)      
# print(s)
  方法二

# sum=""               
# for i in lst:
# sum=sum+i+"_"
# print(sum)
# 字符串连接
# s="金","木","水","火","土"
# s1="_".join(s)
# print(s1)
 元组连接
# tu=("男","女","老","少")
# tu1="_".join(tu)
# print(tu1) 2 list删除问题
# lst=["红","橙","黄","绿","青","蓝","紫"]
 方法一   clear
# lst.clear()
# print(lst)
方法二  del     range(0,len(lst))
# for i in range(0,7):
# del lst[0]
# print(lst) 方法三 pop range(0,len(lst))
# for i in range(0,7):
# lst.pop(0)
# print(lst)
 方法四     把要删除的元素保存在新列表中,循环新列表,删除旧列表.
# lst1=[]
# for i in lst:
# lst1.append(i)
# for el in lst1:
# lst.remove(el)
# print(lst)
3  dict 中的fromkey( )
#fromkey :  第一个参数中每一个拿出来和第二个参数组织成键值对.
#注意代码中只是更改了jay那个列表. 但是由于jay和JJ⽤的是同⼀个列表. 所以. 前⾯那个改了. 后⾯那个也会跟着改.
# dic=dict.fromkeys(["jay","jj"],["周杰伦","林俊杰"])
# dic.get("jay").append("蔡依林")
# print(dic)
4. dic中的元素在迭代过程中是不可以删除的.,需要把要删除的内容存在新列表中,循环新列表,删除旧列表
# lst=["红","橙","黄","绿","青","蓝","紫"]
# lst1=["黄","绿"]
# for el in lst1:
# lst.remove(el)
# print(lst)
5.  set() 集合 是dict类型的数据,只存key的值,不存value的值.
特点: 元素不重复(应用"去重");无序;内容必须不可变(可哈希);set本身是可变的(增删改).
去重:
# lst=["红","橙","黄","绿","青","蓝","紫","青","绿"]
# s=set(lst)
# print(s)
set 是可变的,里面内容是不可变的
# s={"alex",1,True,{"你好"}}    不可行,因为{"你好"}不可哈希( 可变的)
#s={"麻花",[1,2,3,]} 不可行 因为[1,2,3]是列表,列表不可哈希( 可变的)
#s={"听","说","读","写",(1,3)} 可行 因为(1,3)是元组,元组是不可变的(可哈希)
6.set  增  删  改  查
增一
# s=set()
# s.add("大神")
# print(s)
增二   update迭代更新
# s={"赵","钱","孙","李","张","王"}
# s.update("吉孔孟")
# print(s)
# s.update(["中国"])
# print(s)
# s.update(["中","国"])
# print(s)
删一  pop()  随机删除
# s={"赵","钱","孙","李","张","王"}
# s1=s.pop()
# print(s1) 删除的元素
# print(s) 删除以后的结果
# 删二clear   打印出来是set()
删三remove
# s.remove("王")   删除指定元素
# print(s)
#修改  set无法直接修改,先删掉,再增加.
# s={"赵","钱","孙","李","张","王"}
# s.remove("王")
# s.add("吉")
# print(s)
查询
# s={"赵","钱","孙","李","张","王"}
# for el in s:
# print(el)
7.   其他操作
#交集    print(s1 and s2)
# s1={"赵","钱","孙","李","张","王"}
# s2={"赵","钱","孙","李","张","王","吉","宋"}
# print(s1&s2)
# print(s1.intersection(s2))
并集
# s1={"赵","钱","孙","李","张","王"}
# s2={"赵","钱","孙","李","张","王","吉","宋"}
# print(s1|s2)
# print(s1.union(s2))
 差集 print(s1-s2)  得到第一个中单独存在的
# s1={"赵","钱","孙","李","张","王","杜"}
# s2={"赵","钱","孙","李","张","王","吉","宋"}
# print(s1-s2)
# print(s1.difference(s2))
反交集   两个集合中单独存在的数据  (和交集相反)
# s1={"赵","钱","孙","李","张","王","杜"}
# s2={"赵","钱","孙","李","张","王","吉","宋"}
# print(s1^s2)
# print(s1.symmetric_difference(s2))
#子集  print(s1<s2)   set1是set2 的子集吗
# s1={"赵","钱","孙","李","张","王",}
# s2={"赵","钱","孙","李","张","王","吉","宋"}
# # print(s1<s2)
# print(s1.issubset(s2))
超集  print(s1<s2) print(s1.issuperset(s2))
# s1={"赵","钱","孙","李","张","王",}
# s2={"赵","钱","孙","李","张","王","吉","宋"}
# print(s1>s2)
# print(s1.issuperset(s2))
 8.  set集合本身是可以发⽣改变的. 是不可hash的. 我们可以使⽤frozenset来保存数据.frozenset是不可变的. 也就是⼀个可哈希的数据类型
# s1={"赵","钱","孙","李","张","王",}
# s=frozenset(s1)
# dic={s1:"123"}
# print(dic)
#9.深浅拷贝

(1)赋值:对于list, set, dict来说, 直接赋值. 其实是把内存地址交给变量. 并不是复制⼀份内容. 所以.lst1的内存指向和lst2是⼀样的. lst1改变了, lst2也发⽣了改变
list列表
# lst1=["红","橙","黄","绿","青","蓝","紫"]
# lst2=lst1
# print(lst1)
# print(lst2)
# lst1.append("粉")
# print(lst1)
# print(lst2)
ict字典
# dic1={"颜色":"红色","水果":"香蕉"}
# dic2=dic1
# print(dic1)
# print(dic2)
# dic1["蔬菜"]="番茄"
# print(dic1)
# print(dic2)
(2)浅拷贝    只拷贝第一层,第二层的内容不拷贝
# lst1=["风","雨","雪","霜"]
# lst2=lst1.copy()
# lst1.append("冰雹")
# print(lst1)
# print(lst2)
# print(id(lst1),id(lst2))
2
# lst2=["风","雨","雪","霜",["电","雷"]]
# lst3=lst2.copy()
# print(lst3)
# lst2[4].append("冰雹")
# print(lst2)
# print(lst3)
(3)深拷贝    把元素内部的元素完全进⾏拷⻉复制. 不会产⽣⼀个改变另⼀个跟着改变的问题
# import copy
# lst1=["番茄","白菜","胡萝卜",["苹果","荔枝","香蕉"]]
# lst2=copy.deepcopy(lst1)
# print(lst1)
# print(lst2)
# lst1[3].append("芒果")
# print(lst1)
# print(lst2)
 

.

list的删除问题

四.set 的集合

五深浅拷贝

python全栈开发 * 07知识点汇总 * 180607的更多相关文章

  1. python全栈开发 * 10知识点汇总 * 180612

    10 函数进阶 知识点汇总 一.动态参数 形参的第三种1.动态接收位置传参 表达:*args (在参数位置编写 * 表⽰接收任意内容) (1)动态位置参数def eat(*args): print(a ...

  2. python全栈开发 * 01知识点汇总 * 180530

    一 python简介. 1.创始人:  吉多 .范罗苏姆  \   (Guido van Rossum). 2.时间  :  1989年. 3.主要应用领域  :  云计算 \  WEB开发  \   ...

  3. python全栈开发 * 32知识点汇总 * 180717

    32 网络编程 (一)一.架构 定义:程序员开发的一种模式. 分类: C/S 架构 C/S即:Client与Server , 客户端/ 服务器模式 . 缺点 : 冗余 B/S 架构 Browser与S ...

  4. python全栈开发 * 27知识点汇总 * 180710

    27   time  os  sys  模块 time 模块 一.表示时间的三种方式 时间戳(timestamp), 元组(struct_time),格式化时间字符串(Format string) 小 ...

  5. python全栈开发 * 26知识点汇总 * 180709

    26 logging collections random 模块 一.logging低配:日志不能写入文件与显示同时进行 import logging logging.basicConfig(leve ...

  6. python全栈开发 * 12 知识点汇总 * 180530

    12 知识点总结 装饰器进阶 ⼀. 通⽤装饰器的回顾1.开闭原则: 对增加功能开放. 对修改代码封闭2.装饰器的作⽤: 在不改变原有代码的基础上给⼀个函数增加功能3.通⽤装饰器的写法:def wrap ...

  7. python全栈开发 * 36知识点汇总 * 180721

    36 操作系统的发展史 进程一.手工操作--穿孔卡片 1.内容: 程序员将对应于程序和数据的已穿孔的纸带(或卡片)装入输入机,然后启动输入机把程序和数据输入计算机内存,接着通过控制 台开关启动程序针对 ...

  8. python全栈开发 * 31知识点汇总 * 180716

    31 模块和包一.模块(一)模块的种类:内置模块,自定义模块,扩展模块第三方模块(二)自定义模块 1.模块的创建 : 新建一个py文件. 2.模块名 : 模块名需要符合变量的命名规范. 3.模块的导入 ...

  9. python全栈开发 * 24 知识点汇总 * 180705

    24 模块-------序列化一.什么是模块 模块:py文件就是一个模块.二.模块的分类:(1)内置模块 (登录模块,时间模块,sys模块,os模块)(2)扩展模块 (itchat 微信有关,爬虫,b ...

随机推荐

  1. 修改Electron的libcc(libchromiumcontent)源码,重新编译electron, 设置event.isTrusted为true

    VPN非常注意: 编译的过程需要使用VPN, 否者chromium的源代码无法下载, 后面会出现总总问题 Electron的编译环境, 推荐使用物理机: win10 64位 英文版, 为了避免后期出现 ...

  2. typescript 与 js 开发 react 的区别

    一.从定义文件格式方面说1.传统的开发模式可以定义js文件或者jsx文件2.利用ts开发定义的文件格式tsx二.定义state的状态来说1.传统的方式直接在构造函数中使用 constructor(){ ...

  3. 小程序学习笔记二:页面文件详解之 .json文件

       页面配置文件—— pageName.json 每一个小程序页面可以使用.json文件来对本页面的窗口表现进行配置,页面中配置项会覆盖 app.json 的 window 中相同的配置项. 页面的 ...

  4. GDAL指定自定义的金字塔目录

    缘起 对于一般的遥感影像文件,金字塔文件默认都是与影像文件放在同一个目录下,金字塔文件名一般与源影像文件名相同,但后缀名不同.或者金字塔内建于影像内部,但这不是这里所涉及的. 在使用ArcGIS桌面版 ...

  5. MongoDB地理空间数据存储及检索

    目录 1.存入地理数据 GeoJSON数据存入 1.Ponit 点数据 2.LineString 线数据(多段线) 3. Polygon 多边形数据 4.MultiPoint多点.MultiLineS ...

  6. linux 通过nvm安装node

    官方介绍:https://github.com/creationix/nvm#installation PS:通常不要用root权限安装软件,因为线上任何服务部署都不允许用root,其他软件用root ...

  7. centos 环境搭建jenkins服务

    1.下载jenkins war包 https://jenkins.io/download/ 选择Generic Java package (.war)下载2.下载apache tomcat 8 htt ...

  8. ThreadPoolExcutor 线程池 异常处理 (下篇)

    前言 因为这是之前面试的一个题目,所以印象比较深刻,前几天写了一篇文章:ThreadPoolExcutor 线程池 异常处理 (上篇) 中已经介绍了线程池异常的一些问题以及一步步分析了里面的一些源代码 ...

  9. c语言搜索子字符串

    c字符串功能练习: 获取一行字符串,然后,在这行字符串中搜索是否包含一个小字符串 #include <cstdio> #include <cstring> #define N ...

  10. 优化实现Mobile/Bumped Diffuse

    在上一篇帖子的基础上增加一张法线贴图即可: Shader "James/Scene/Bumped_Diffuse" { Properties { _MainTex ("B ...