day7-集合
一、定义变量是为了吹处理状态的变化,定义变量名是为了获取变量值。
字符串、数字、列表、元组、字典都是为了更好的描述变量的状态
1.可变不可变:变量名不变时,里面内容是否可以变化
# 可变:列表、字典。修改变量的值,ID不变
li = ['df','dfdf']
print(id(li)) #
li[0]='fkjg'
print(li)
print(id(li)) # 2076395786824 同一id地址,列表内内容可变化
# 不可变:字符串、数字、元组修改变量的值,ID变化
name = '马达'
print(id(name)) #
name = 'nkf'
print(id(name)) # 1951110131888 id不变,内容不可变
# 2.访问顺序:
# 可按照索引顺序访问:字符串、列表、元组(都是有序的)
# 映射方式访问;字典(一个key 对应一个value)
# 直接访问:数字 # 3:存放元素个数
# 容器类型(数据类型可存放多个值):列表、元组、字典
# 原子类型(只能存放一个值):数字、字符串
二.集合:定义集合可以用大括号{,,,} or 系统内置函数set,set里面的内容必须可迭代
# 由不同元素组成,
# 元素无序,
# 集合中元素必须是不可变类型-只能存放数字、字符串、元组
s = set('hello')
print(s) # {'l', 'h', 'o', 'e'}
s = set((1,'djf'))
print(s) # {1, 'djf'}
--add()添加
--clear()清空
--copy()复制
s.add('s')
s.add('')
s.add(3)
print(s) # {1, 2, 3, 4, 5, 6, 's', '3'} s.clear()
print(s) # set() s1=s.copy()
--pop() # 集合无序,随机删除
--s.remove() # 指定删除元素,当删除元素不存在时,会报错
--discard() # 删除指定元素,元素不存在时也不报错
s = {'df',1,2,3,4,5}
s.pop() # 集合无序,随机删除
print(s) # {2, 3, 4, 5, 'df'} # s.remove() # 指定删除元素,当删除元素不存在时,会报错
s.remove('jflkd')
print(s) # KeyError: 'jflkd' s.discard('dfjk') # 删除指定元素,元素不存在时也不报错
print(s) # {2, 3, 4, 5, 'df'}
--intersection()求交集:我们都有 --union()求并集 :全部
--difference()求差集:我有你没有 --symmetric_difference()交叉补集 并集-交集 我有你没有的组合
--difference_update:等同于p_s=p_s-l_s
--isdisjoint() 如果两个集合没有交集则返回True,否则返回False
--issubset()判断是否为子集
--issuperset()判断是否为父集
--update()更新多个值,可迭代的对象都能传进去
# s1.add(1,2,3,4) #更新一个值
# s1.union(s2) #不更新
python_l=['lcg','szw','zjw','lcg']
linux_l=['lcg','szw','sb']
p_s=set(python_l)
l_s=set(linux_l) # # intersection()求交集:我们都有
print(p_s,l_s) # {'lcg', 'zjw', 'szw'} {'lcg', 'sb', 'szw'}
print(p_s.intersection(l_s)) # 'lcg', 'szw'}
print(p_s&l_s) # $求交集 {'lcg', 'szw'} # # union()求并集 :全部
print(p_s.union(l_s))
print(p_s|l_s) # |求并集 {'zjw', 'szw', 'lcg', 'sb'} # # difference()求差集:我有你没有
print('差集',p_s-l_s) # -求差集: 差集 {'zjw'}
print(p_s.difference(l_s))
print('差集',l_s-p_s) # 差集 {'sb'}
print(l_s.difference(p_s)) # symmetric_difference()交叉补集 并集-交集 我有你没有的组合
print('交叉补集',p_s.symmetric_difference(l_s)) # 交叉补集 {'sb', 'zjw'}
print('交叉补集',p_s^l_s) # ^交叉补集符号 python_l=['lcg','szw','zjw','lcg']
linux_l=['lcg','szw','sb']
p_s=set(python_l)
l_s=set(linux_l)
print(p_s,l_s) # {'lcg', 'zjw', 'szw'} {'lcg', 'sb', 'szw'}
# print('差集',p_s-l_s)
# difference_update:等同于p_s=p_s-l_s
p_s.difference_update(l_s) # {'zjw'}
print(p_s) # isdisjoint() 如果两个集合没有交集则返回True,否则返回False
s1={1,2}
s2={2,3,5}
print(s1.isdisjoint(s2)) # False s1={1,2}
s2={1,2,3}
print(s1.issubset(s2))#s1 是s2 的子集 True
print(s2.issubset(s1))#False print(s2.issuperset(s1))#s1 是s2 的父集 True s1={1,2}
s2={1,2,3,4}
s1.update(s2) #更新多个值,可迭代的对象都能传进去
print(s1) # {1, 2, 3, 4} # s1.add(1,2,3,4) #更新一个值
# s1.union(s2) #不更新
s=frozenset('hello')
# 集合是可变的,frozenset设置不可变集合
print(s) # frozenset({'o', 'e', 'h', 'l'})
names=['alex','alex','wupeiqi']
names=list(set(names)) print(names) # 'alex', 'wupeiqi'] 通过集合删除列表中重复值
day7-集合的更多相关文章
- [ python ] 学习目录大纲
简易博客[html+css]练习 MySQL 练习题及答案 MySQL视图.触发器.函数.存储过程 MySQL 操作总结 Day41 - 异步IO.协程 Day39/40 - 线程的操作 Day36/ ...
- python 全栈开发,Day7(元组转换,列表以及字典的坑,集合,关系测试,深浅copy,编码补充)
一.元组转换 数字 tu = (1) tu1 = (1,) print(tu,type(tu)) print(tu1,type(tu1)) 执行输出: 1 <class 'int'>(1, ...
- Python基础学习Day7 基础数据类型的扩展 集合 深浅copy
一.基础数据类型的扩展 1.1GBK ---> UTF - 8 # str --->bytes s1 = '太白' # 字符串是unicode编码 b1 = s1.encode('gbk' ...
- python day- 7 进本数据类型的先关知识点 set集合 深浅拷贝
一.基本数据类型相关知识 1.str. join()函数 关于字符串 a = "我爱北京" b = a.join("真的") 将&q ...
- day7 基础数据类型&集合&深浅拷贝
基础数据类型汇总: #!/usr/bin/env python # -*- coding:utf-8 -*- ''' str int ''' # str s = ' a' print(s.isspac ...
- Python之路,Day7 - Python基础7 面向对象
本节内容: 面向对象编程介绍 为什么要用面向对象进行开发? 面向对象的特性:封装.继承.多态 类.方法. 引子 你现在是一家游戏公司的开发人员,现在需要你开发一款叫做<人狗大战> ...
- Alpha冲刺集合
Alpha冲刺集合 Day1 http://www.cnblogs.com/bugLoser/p/7901016.html Day2 http://www.cnblogs.com/bugLoser/p ...
- Alpha阶段敏捷冲刺日志的集合贴
敏捷冲刺日志的集合贴 Day1(4.17):http://www.cnblogs.com/software-teamwork/p/8861426.html Day2(4.20):http://www. ...
- 10.23 正睿停课训练 Day7
目录 2018.10.23 正睿停课训练 Day7 A 矩形(组合) B 翻转(思路) C 求和(思路 三元环计数) 考试代码 B1 B2 C 2018.10.23 正睿停课训练 Day7 期望得分: ...
- day 7 -10 集合,文本、文件操作,函数
day7 一.回顾 1.列表和字典在循环里边尽量不要删除元素,很麻烦 2.元组:如果元组里边只有一个逗号,且不加逗号,次元素是什么类型,就是什么类型. 二.集合 ''' 集合:可变的数据类型,它里边的 ...
随机推荐
- 动态扩容lvm逻辑卷的操作记录
在进行动态扩容LVM逻辑卷的之前,先看这篇文章:https://www.cnblogs.com/huhyoung/p/9689776.html.以下是我实操记录. 在上班期间,测试经理突然找我,能不能 ...
- 第3章(1) Linux内核相关概念
Linux内核的组成 1. Linux内核源代码的目录结构 arch:包含和硬件体系结构相关的代码,每种平台占一个相应的目录,如 i386.arm. arm64.powerpc.mips 等.Linu ...
- JavaScript七宗罪和一些槽点
当下JavaScript越来越流行,成为长期霸语言榜前三的语言.但是实际上JavaScript是一个很丑陋有很多槽点的语言,这就是为什么新出了那么多框架(从jQuery到Vue)以及海尔斯伯格大大推出 ...
- [BZOJ3449] [Usaco2014 Feb]Secret Code
Description Farmer John has secret message that he wants to hide from his cows; the message is a str ...
- MySQL 日志系统之 redo log 和 binlog
之前我们了解了一条查询语句的执行流程,并介绍了执行过程中涉及的处理模块.一条查询语句的执行过程一般是经过连接器.分析器.优化器.执行器等功能模块,最后到达存储引擎. 那么,一条 SQL 更新语句的执行 ...
- vue 自定义侧边栏 递归无限子级菜单
有很多网站会涉及到导航栏,我自己在开发中用的是element导航组件,并且自定义事件,给大家分享一下. 1.使用递归方法,无限循环子级菜单. 2.使用组件封装,维护方便. 3.使用index作为路由跳 ...
- vue系列---snabbdom.js使用及源码分析(九)
一:什么是snabbdom? 在学习Vue或React中,我们了解最多的就是虚拟DOM,虚拟DOM可以看作是一颗模拟了DOM的Javascript树,主要是通过vnode实现一个无状态的组件,当组件状 ...
- 【原】iOS开发进阶(唐巧)读书笔记(二)
第三部分:iOS开发底层原理 1.Objective-C对象模型 1.1 isa指针 NSObject.h部分代码: NS_ROOT_CLASS @interface NSObject <NSO ...
- 原版_打字游戏.html
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 又到了卸载Notepad++的时候了?
逛开源中国(OSCHINA),无意中发现一贴<不用Notepad++,你还有这些更好的选择> 才发现,原来 Notepad++ 的作者侯今吾前几天又在 npp 的官网上发表了一篇个人政治意 ...