第十九节,基本数据类型,集合set
集合set,无序,是不允许重复内容的,也就是不允许重复元素,如果有重复,会自动忽略,可接收可迭代类型 (一般用于需要判断和处理交集时候用到)
集合与字典的区别是,集合没有键只有值,字典是有键的字典是一对键值对
所以创建空集合不能用{}大括号,用大括号创建空集合默认会变成字典,如果需要创建空集合用set()
创建集合
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#创建集合
a = set()
a = {11,22,33,44,55,55}
print(a)
#打印出 {33, 11, 44, 22, 55}
转换集合
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#转换集合
a = [11,22,33,44,55]
b = (11,22,33,44,55)
c = ""
#将列表转换成集合
zh_a = set(a)
print(zh_a)
#将元组转换成集合
zh_b = set(b)
print(zh_b)
#将字符串转换成集合
zh_c = set(c)
print(zh_c)
#打印出
#{33, 11, 44, 22, 55}
#{33, 11, 44, 22, 55}
#{'7', '5', '1', '9', '4', '2', '8', '6', '3'}
集合的类库功能
add(self, *args, **kwargs)
"添加元素"(要添加的元素)
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#创建一个集合
se = {11,22,33,44}
#向集合里添加元素
se.add(55)
print(se)
#打印出 {33, 11, 44, 22, 55}
clear(self, *args, **kwargs)
"清空元素"()
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#创建一个集合
se = {11,22,33,44}
#清空集合里的元素
se.clear()
print(se)
#打印出 set() 表示空集合
difference(self, *args, **kwargs)
"查找出一个集合里存在,另外一个集合不存在的元素"(格式:查找集合.difference(被判断的集合))
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#创建二个集合
a = {11,22,33,44}
b = {11,55,88,44}
#查找出a集合里存在,b集合不存在的元素
c = a.difference(b)
print(c)
#打印出 {33, 22}
difference_update(self, *args, **kwargs)
"从当前集合中删除和B中相同的元素"(b集合)
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#创建二个集合
a = {11,22,33,44,999}
b = {11,55,88,44}
#从a集合中删除和B集合中相同的元素
a.difference_update(b)
print(a)
#打印出 {33, 22, 999}
discard(self, *args, **kwargs)
"移除指定元素,不存在不报错"(要移除的元素)
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#创建一个集合
a = {11,22,33,44,999}
#移除指定元素,不存在不报错
a.discard(999)
print(a)
#打印出 {33, 11, 44, 22}
intersection(self, *args, **kwargs)
"交集,查找出a集合和b集合都存在的元素"(b集合)
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#创建二个集合
a = {66,22,33,44,99}
b = {44,55,66,77,33}
#交集,查找出a集合和b集合都存在的元素
c = a.intersection(b)
print(c)
#打印出 {33, 66, 44}
intersection_update(self, *args, **kwargs)
"交集,查找出a集合和b集合都存在的元素,并重新更新到a集合"(b集合)
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#创建二个集合
a = {66,22,33,44,99}
b = {44,55,66,77,33}
#交集,查找出a集合和b集合都存在的元素,并重新更新到a集合
a.intersection_update(b)
print(a)
#打印出 {33, 66, 44}
isdisjoint(self, *args, **kwargs)
"检查a集合和b集合是否有都存在的元素"(b集合)
返回布尔值:如果没有都存在的,返回True,否则返回False
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#创建二个集合
a = {66,22,33,44,99}
b = {44,55,66,77,33}
#检查a集合和b集合是否有都存在的元素,
c = a.isdisjoint(b)
print(c)
#打印出 False 说明有交集
issubset(self, *args, **kwargs)
"判断一个集合是否是另一个集合的子序列"(b集合)
是返回True 不是返回False
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#创建二个集合
a = {11,22,33,44}
b = {11,22}
#检查a集合是否是b集合的子序列,
c1 = a.issubset(b)
print(c1)
#检查b集合是否是a集合的子序列
c2 = b.issubset(a)
print(c2)
#打印出
#False 检查a集合是否是b集合的子序列,说明a集合不是b集合的子序列
#True 检查b集合是否是a集合的子序列,说明b集合是a集合的子序列
issuperset(self, *args, **kwargs)
"判断一个集合是否是另一个集合的父序列"(b集合)
是返回True 不是返回False
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#创建二个集合
a = {11,22,33,44}
b = {11,22}
#检查a集合是否是b集合的父序列,
c1 = a.issuperset(b)
print(c1)
#检查b集合是否是a集合的父序列
c2 = b.issuperset(a)
print(c2)
#打印出
#True 检查a集合是否是b集合的父序列,说明a集合是b集合的父序列
#False 检查b集合是否是a集合的父序列,说明b集合不是a集合的父序列
pop(self, *args, **kwargs)
"移除元素"()
一般默认移除第一个元素,只是集合有一套自己的元素排序规则,
#!/usr/bin/env python
# -*- coding:utf-8 -*-
a = {44,55,66,77,88}
#打印出集合,可以看到集合里的元素排序情况
print(a)
#移除集合里的元素,默认移除元素里的第一个排序元素
b = a.pop()
#打印出被移除的元素
print(b)
#打印出a集合被移除后剩下的所有元素
print(a)
#最后打印出
#{88, 66, 44, 77, 55}
#
#{66, 44, 77, 55}
remove(self, *args, **kwargs)
"移除指定元素,不存在保错"(要移除的元素)
#!/usr/bin/env python
# -*- coding:utf-8 -*-
a = {44,55,66,77,88}
#打印出a集合
print(a)
#移除a集合里指定的元素
a.remove(44)
#打印a集合移除指定元素后,剩下的所有元素
print(a)
#最后输出
#{88, 66, 44, 77, 55}
#{88, 66, 77, 55}
symmetric_difference(self, *args, **kwargs)
"对称差集,就是将两个集合里没有交集的元素重新组合成一个新的集合"(b集合)
#!/usr/bin/env python
# -*- coding:utf-8 -*-
a = {44,55,66,77,88}
b = {44,55,11,22,33}
#对称差集,就是将两个集合里没有交集的元素重新组合成一个新的集合
c = a.symmetric_difference(b)
print(c)
#输出
#{33, 66, 11, 77, 22, 88}
symmetric_difference_update(self, *args, **kwargs)
"对称差集,并更新到a中,就是将两个集合里没有交集的元素重新组合更新给a集合"(b集合)
#!/usr/bin/env python
# -*- coding:utf-8 -*-
a = {44,55,66,77,88}
b = {44,55,11,22,33}
#对称差集,并更新到a中,就是将两个集合里没有交集的元素重新组合更新给a集合
a.symmetric_difference_update(b)
print(a)
#输出
#{33, 66, 11, 77, 22, 88}
union(self, *args, **kwargs)
"并集,将两个集合合并成一个新的集合,元素有重复的会自动忽略"(b集合)
#!/usr/bin/env python
# -*- coding:utf-8 -*-
a = {44,55,66,77,88}
b = {44,55,11,22,33}
#并集,将两个集合合并成一个新的集合,元素有重复的会自动忽略只保留一次
c = a.union(b)
print(c)
#输出
#{33, 66, 11, 44, 77, 22, 55, 88}
update(self, *args, **kwargs)
"更新,将b集合更新到a集合,相当于合并"(b集合)
#!/usr/bin/env python
# -*- coding:utf-8 -*-
a = {44,55,66,77,88}
b = {44,55,11,22,33}
#更新,将b集合更新到a集合,相当于合并
a.update(b)
print(a)
#输出
#{33, 66, 11, 44, 77, 22, 55, 88}
第十九节,基本数据类型,集合set的更多相关文章
- 第三百二十九节,web爬虫讲解2—urllib库爬虫—ip代理—用户代理和ip代理结合应用
第三百二十九节,web爬虫讲解2—urllib库爬虫—ip代理 使用IP代理 ProxyHandler()格式化IP,第一个参数,请求目标可能是http或者https,对应设置build_opener ...
- 第三百八十九节,Django+Xadmin打造上线标准的在线教育平台—列表筛选结合分页
第三百八十九节,Django+Xadmin打造上线标准的在线教育平台—列表筛选结合分页 根据用户的筛选条件来结合分页 实现原理就是,当用户点击一个筛选条件时,通过get请求方式传参将筛选的id或者值, ...
- 第三百七十九节,Django+Xadmin打造上线标准的在线教育平台—xadmin的安装
第三百七十九节,Django+Xadmin打造上线标准的在线教育平台—xadmin的安装 xadmin介绍 xadmin是基于Django的admin开发的更完善的后台管理系统,页面基于Bootstr ...
- 第三百六十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)用Django实现搜索功能
第三百六十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)用Django实现搜索功能 Django实现搜索功能 1.在Django配置搜索结果页的路由映 ...
- 第三百五十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)介绍以及安装
第三百五十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)介绍以及安装 elasticsearch(搜索引擎)介绍 ElasticSearch是一个基于 ...
- 第三百四十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—cookie禁用、自动限速、自定义spider的settings,对抗反爬机制
第三百四十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—cookie禁用.自动限速.自定义spider的settings,对抗反爬机制 cookie禁用 就是在Scrapy的配置文件set ...
- 第三百三十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—Scrapy启动文件的配置—xpath表达式
第三百三十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—Scrapy启动文件的配置—xpath表达式 我们自定义一个main.py来作为启动文件 main.py #!/usr/bin/en ...
- 第三百一十九节,Django框架,文件上传
第三百一十九节,Django框架,文件上传 1.自定义上传[推荐] 请求对象.FILES.get()获取上传文件的对象上传对象.name获取上传文件名称上传对象.chunks()获取上传数据包,字节码 ...
- centos shell编程5 LANMP一键安装脚本 lamp sed lnmp 变量和字符串比较不能用-eq cat > /usr/local/apache2/htdocs/index.php <<EOF重定向 shell的变量和函数命名不能有横杠 平台可以用arch命令,获取是i686还是x86_64 curl 下载 第三十九节课
centos shell编程5 LANMP一键安装脚本 lamp sed lnmp 变量和字符串比较不能用-eq cat > /usr/local/apache2/htdocs/ind ...
随机推荐
- sql server 查询表基本信息sql
SELECT c.name,t.name TYPE,c.max_length,c.precision,c.scale,p.value FROM sys.systypes t INNER JOIN sy ...
- coordinate transformation
$X_{0}$为$I$在$O_{0}$系的坐标${\left(\begin{array}{c}x_0 \\y_0 \\z_0 \\\end{array}\right)}$,$X_{1}$为$I$在$O ...
- document.compatMode属性介绍
之前不了解这个属性,今天总结一下,以后可能会用到. 对于document.compatMode,很多朋友可能都根我一样很少接触,知道他的存在却不清楚他的用途.今天在ext中看到 document.co ...
- Spire.XLS 在程序中直接打印excel
上代码 if (tbPrintSetBindingSource.Current == null) return; var item_TbPrintSet = tbPrintSetBindingSour ...
- yield 学习笔记
第三部分(先看) 先讲 iterator 和 iterable 可迭代对象 (Iterable) 是实现了__iter__()方法的对象, 通过调用iter()方法可以获得一个迭代器 (Iterato ...
- Java--最大子序列和实现
package com.dongbin.test; /** * 最大子序列和 --分治法 * * @author dongbin * */ public class MaxSubListSum { / ...
- react起步
react是一个用于构建用户界面JAVASCRIPT库. react主要用于构建UI,是MVC中的V(视图). react特点 1.声明式设计 2.高效 3.灵活 4.JSX 5.组件 6.单项响应的 ...
- 第16 天 JavaWEB过滤器和监听器技术
Day16 JavaWEB过滤器和监听器技术 复习: 1.大结果集分页mysql的实现,是使用那个关键字,从user表中取第一页的数据,长度为10,sql语句怎么写? 2.分页查询的起始位置(star ...
- 安卓访问webAPI,并取回数据
前言 安卓自从4.0以后,所有的网络访问都需要异步进程操作.其自带的异步类有AsyncTask,Handler,以及可以声明Thread等等.涉及到多进程,必须要提到一个问题,线程与线程之间不能直接进 ...
- 1.javaOOP_Part1_抽象和封装
javaOOP_Part1_抽象和封装 javaOOP_Part1_抽象和封装 1.1 面向对象 1.1.1 为什么使用面向对象 1.一切皆对象 2.现实世界就是"面向对象的" 3 ...