python全栈开发 * 07知识点汇总 * 180607
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的更多相关文章
- python全栈开发 * 10知识点汇总 * 180612
10 函数进阶 知识点汇总 一.动态参数 形参的第三种1.动态接收位置传参 表达:*args (在参数位置编写 * 表⽰接收任意内容) (1)动态位置参数def eat(*args): print(a ...
- python全栈开发 * 01知识点汇总 * 180530
一 python简介. 1.创始人: 吉多 .范罗苏姆 \ (Guido van Rossum). 2.时间 : 1989年. 3.主要应用领域 : 云计算 \ WEB开发 \ ...
- python全栈开发 * 32知识点汇总 * 180717
32 网络编程 (一)一.架构 定义:程序员开发的一种模式. 分类: C/S 架构 C/S即:Client与Server , 客户端/ 服务器模式 . 缺点 : 冗余 B/S 架构 Browser与S ...
- python全栈开发 * 27知识点汇总 * 180710
27 time os sys 模块 time 模块 一.表示时间的三种方式 时间戳(timestamp), 元组(struct_time),格式化时间字符串(Format string) 小 ...
- python全栈开发 * 26知识点汇总 * 180709
26 logging collections random 模块 一.logging低配:日志不能写入文件与显示同时进行 import logging logging.basicConfig(leve ...
- python全栈开发 * 12 知识点汇总 * 180530
12 知识点总结 装饰器进阶 ⼀. 通⽤装饰器的回顾1.开闭原则: 对增加功能开放. 对修改代码封闭2.装饰器的作⽤: 在不改变原有代码的基础上给⼀个函数增加功能3.通⽤装饰器的写法:def wrap ...
- python全栈开发 * 36知识点汇总 * 180721
36 操作系统的发展史 进程一.手工操作--穿孔卡片 1.内容: 程序员将对应于程序和数据的已穿孔的纸带(或卡片)装入输入机,然后启动输入机把程序和数据输入计算机内存,接着通过控制 台开关启动程序针对 ...
- python全栈开发 * 31知识点汇总 * 180716
31 模块和包一.模块(一)模块的种类:内置模块,自定义模块,扩展模块第三方模块(二)自定义模块 1.模块的创建 : 新建一个py文件. 2.模块名 : 模块名需要符合变量的命名规范. 3.模块的导入 ...
- python全栈开发 * 24 知识点汇总 * 180705
24 模块-------序列化一.什么是模块 模块:py文件就是一个模块.二.模块的分类:(1)内置模块 (登录模块,时间模块,sys模块,os模块)(2)扩展模块 (itchat 微信有关,爬虫,b ...
随机推荐
- ORA-12514 TNS:LISTENER DOES NOT CURRENTLY KNOW OF SERVICE REQUESTED IN CONNE
对比Oracle服务器地址,端口号,还有实例名(也就是服务名).修改tnsnames.ora 在Oracle客户端的安装目录底下. 然后用sqlplus [用户名]/[密码]@[服务命名] 服务命名 ...
- 分析轮子(六)- LinkedList.java
注:玩的是JDK1.7版本 一:先上类的继承结构图 二:再看一下他的底层实现数据结构 三:然后从源码中找点好玩的东西 1)双向链表的结构构成元素,头指针.尾指针.节点信息(前向指针.后向指针.节点信息 ...
- android Glide简单使用
版权声明:大家可以转载,请写明转载申明 https://blog.csdn.net/bzlj2912009596/article/details/81702367 今天,简单讲讲Android里Gli ...
- PEP 492 -- Coroutines with async and await syntax 翻译
因为工作中慢慢开始用python的协程,所以想更好的理解一下实现方式,故翻译此文 原文中把词汇表放到最后,但是我个人觉得放在最开始比较好,这样可以增加当你看原文时的理解程度 词汇表 原生协程函数 Na ...
- Python中的__name__和类
1. python中if __name__ == '__main__': 的解析 经常会在代码的最下面看到if __name__ == '__main__':,现在就来介 绍一下它的作用. 模块是 ...
- 【原创 Hadoop&Spark 动手实践 12】Spark MLLib 基础、应用与信用卡欺诈检测系统动手实践
[原创 Hadoop&Spark 动手实践 12]Spark MLLib 基础.应用与信用卡欺诈检测系统动手实践
- hdoj:2049
#include <iostream> using namespace std; ]; /* n 个 数中 m个错排 转化为:充n个数中选取m个数,共有C(n,m)中,选取的m个数进行全部 ...
- adb logcat查看某个进程的输出日志
adb logcat查看某个进程的输出日志 adb logcat 默认是没有这个功能的,我实现了一个小bash函数,添加到你$HOME/.bashrc 文件中: # 作用:能够通过进程名显示log # ...
- BarTender 2016如何导出模板为pdf文件?
最近有小伙伴来问,BarTender 2016能不能导出模板为pdf文件?这个是可以的,之前针对BarTender 10.1就介绍过一种方法了.本文,小编再针对BarTender 2016给大家讲下如 ...
- Cesium高度解析
var viewer = new Cesium.Viewer('cesiumContainer', { shadows : true }); //为true时,球体会有高程遮挡效果(在没有地形时候也会 ...