一、定义变量是为了吹处理状态的变化,定义变量名是为了获取变量值。
字符串、数字、列表、元组、字典都是为了更好的描述变量的状态
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-集合的更多相关文章

  1. [ python ] 学习目录大纲

    简易博客[html+css]练习 MySQL 练习题及答案 MySQL视图.触发器.函数.存储过程 MySQL 操作总结 Day41 - 异步IO.协程 Day39/40 - 线程的操作 Day36/ ...

  2. python 全栈开发,Day7(元组转换,列表以及字典的坑,集合,关系测试,深浅copy,编码补充)

    一.元组转换 数字 tu = (1) tu1 = (1,) print(tu,type(tu)) print(tu1,type(tu1)) 执行输出: 1 <class 'int'>(1, ...

  3. Python基础学习Day7 基础数据类型的扩展 集合 深浅copy

    一.基础数据类型的扩展 1.1GBK ---> UTF - 8 # str --->bytes s1 = '太白' # 字符串是unicode编码 b1 = s1.encode('gbk' ...

  4. python day- 7 进本数据类型的先关知识点 set集合 深浅拷贝

    一.基本数据类型相关知识 1.str.    join()函数 关于字符串 a = "我爱北京" b = a.join("真的")            将&q ...

  5. day7 基础数据类型&集合&深浅拷贝

    基础数据类型汇总: #!/usr/bin/env python # -*- coding:utf-8 -*- ''' str int ''' # str s = ' a' print(s.isspac ...

  6. Python之路,Day7 - Python基础7 面向对象

    本节内容:   面向对象编程介绍 为什么要用面向对象进行开发? 面向对象的特性:封装.继承.多态 类.方法.     引子 你现在是一家游戏公司的开发人员,现在需要你开发一款叫做<人狗大战> ...

  7. Alpha冲刺集合

    Alpha冲刺集合 Day1 http://www.cnblogs.com/bugLoser/p/7901016.html Day2 http://www.cnblogs.com/bugLoser/p ...

  8. Alpha阶段敏捷冲刺日志的集合贴

    敏捷冲刺日志的集合贴 Day1(4.17):http://www.cnblogs.com/software-teamwork/p/8861426.html Day2(4.20):http://www. ...

  9. 10.23 正睿停课训练 Day7

    目录 2018.10.23 正睿停课训练 Day7 A 矩形(组合) B 翻转(思路) C 求和(思路 三元环计数) 考试代码 B1 B2 C 2018.10.23 正睿停课训练 Day7 期望得分: ...

  10. day 7 -10 集合,文本、文件操作,函数

    day7 一.回顾 1.列表和字典在循环里边尽量不要删除元素,很麻烦 2.元组:如果元组里边只有一个逗号,且不加逗号,次元素是什么类型,就是什么类型. 二.集合 ''' 集合:可变的数据类型,它里边的 ...

随机推荐

  1. 落谷P3941 入阵曲

    题目背景 pdf题面和大样例链接:http://pan.baidu.com/s/1cawM7c 密码:xgxv 丹青千秋酿,一醉解愁肠. 无悔少年枉,只愿壮志狂. 题目描述 小 F 很喜欢数学,但是到 ...

  2. SEER见证人操作指南

    SEER的见证人设计 共识方式 在区块生产者的产生方式上,SEER采取了PoS的共识方式,用户通过智能合约抵押自己持有的SEER竞选主力见证人(区块生产者). 对于SEER区块链来说,制约区块链TPS ...

  3. JVM垃圾回收(下)

    接着上一篇,介绍完了 JVM 中识别需要回收的垃圾对象之后,这一篇我们来说说 JVM 是如何进行垃圾回收. 首先要在这里介绍一下80/20 法则: 约仅有20%的变因操纵着80%的局面.也就是说:所有 ...

  4. 快速入门Maven(二)(Eclipse构建Maven项目)

    Mars2的eclipse()已经集成了Maven插件,所以用这个版本不需要装插件了. 接下来构建: 一.调整Eclipse设置 1.选择3.3.9版本的maven软件 2.修改默认的本地仓库地址 二 ...

  5. Display 1 No cameras rendering

    解决: 点击Main Camera ,

  6. 从前端到全栈:JavaScript逆袭之路

    JavaScript如何做到上天入地无所不能?JavaScript真的能一统江湖吗? 背景 近年来,前端技术日新月异,前端已经不仅仅是网页,更多的开始由狭义向广义发展. 先后涌现出了具备后端能力的no ...

  7. Cocos2d-x 学习笔记(7) 内存管理 Sprite SpriteFrame Texture2D

    1. 总结 Sprite和SpriteFrame和Texture2D关系紧密,三个类都继承了Ref类.精灵有成员精灵帧和纹理,精灵帧有成员纹理.精灵帧和纹理被精灵帧引用时,引用计数增加,不再被引用时, ...

  8. 浅谈K-means聚类算法

    K-means算法的起源 1967年,James MacQueen在他的论文<用于多变量观测分类和分析的一些方法>中首次提出 “K-means”这一术语.1957年,贝尔实验室也将标准算法 ...

  9. leetcode 刷500道题,笔试/面试稳过吗?谈一谈这些年来算法的学习

    想要学习算法.应付笔试或者应付面试手撕算法题,相信大部分人都会去刷 Leetcode,有读者问?如果我在 leetcode 坚持刷它个 500 道题,以后笔试/面试稳吗? 这里我说下我的个人看法,我认 ...

  10. 百万年薪python之路 -- 装饰器

    装饰器 1.1 开放封闭原则 开放封闭原则具体定义是这样: 1.对扩展是开放的 我们说,任何一个程序,不可能在设计之初就已经想好了所有的功能并且未来不做任何更新和修改.所以我们必须允许代码扩展.添加新 ...