Python基础 之 set集合 与 字符串格式化
数据类型的回顾与总结
可变与不可变
1.可变:列表,字典
2.不可变:字符串,数字,元组
访问顺序:
1.直接访问:数字
2.顺序访问:字符串,列表,元祖
3.映射:字典
存放元素个数:
容器类型:列表,元祖,字典
原子:数字,字符串
set 集合
一、集合的基本属性
1.不同元素组成
2.无序
3.集合中元素必须是不可变类型(字符串,数字,元组)
s = {1,2,3,4,5,6}
s = {1,2,3,3,3,3,3}
print(type(s))
print(s)
#<class 'set'>
#{1, 2, 3}
set
定义方式
s = set('hello')
print (s)
#{'h', 'e', 'l', 'o'} s1 = set('hello')
print(s1) s2 = set(['root','root','even'])
print(s2) #{'e', 'o', 'l', 'h'}
#{'even', 'root'}
set 集合 使用 for 循环里面的类型
如果有重复的值,则丢弃
二、集合的方法
1.add
添加,只能更新一个值,更新多个值使用 update
s = {1,2,3,4,5,6}
s.add('s')
print(s)
#{1,2,3,4,5,6,'s'}
add
2.clear
清除
s = {1,2,3,4,5,6}
s.clear()
print(s)
#set()
clear
3.copy
拷贝值
s1 = {1,2,3,4,5,6}
s2 = s1.copy()
print(s2)
#{1, 2, 3, 4, 5, 6}
copy
4.pop
随机删除一个值,并保留该值
s = {'e',1,2,3,4,5,6}
n = s.pop()
print(s)
print(n)
#{2, 3, 4, 5, 6, 'e'}
#
pop
5.remove
删除指定值,若删元素不存在,IDEA会报错
s = {'e',1,2,3,4,5,6}
s.remove('e')
print(s)
#{1, 2, 3, 4, 5, 6} 注意:
s = {'e',1,2,3,4,5,6}
s.remove('root') #删除元素不存在,会报错
print(s)
remove
6.discard
删除指定值,若要删除的元素不存在,IDEA不会报错
s = {'e',1,2,3,4,5,6}
s.discard('root') #删除元素不存在,不会报错
print(s)
#{1, 2, 3, 4, 5, 6, 'e'}
discard
三、集合关系运算
现在有两个列表,求他们的交集
足球队人员是张三、李四、王五
篮球队人员是张三、王五、赵六
football = ['张三','李四','王五']
basketball = ['张三','王五','赵六']
#会踢足球的人员和会打篮球的人员
#如果不使用set集合的方式,使用list方式进行for循环,输出两门球类运动都会的人 all = [] #定义一个两门都会的空列表
for f in football: #将football内的元素for循环
if f in basketball: #如果这些元素也在basketball内
all.append(f) #添加这些元素进入[]空列表 print(all)
#['张三', '王五']
1.intersection() 交集
通过 set的方法完成上面的要求
football = ['张三','李四','王五']
basketball = ['张三','王五','赵六']
#会踢足球的人员和会打篮球的人员
#使用set交集的方式,输出两门球类运动都会的人 f_s = set(football) #将football转换为f_s集合
b_s = set(basketball) #将basketball转换为b_s集合 print(f_s,b_s)
print(f_s.intersection(b_s)) #取f_s和b_s的交集 #{'张三', '王五', '李四'} {'张三', '王五', '赵六'}
#{'张三', '王五'}
2.union() 并集
football = ['张三','李四','王五']
basketball = ['张三','王五','赵六']
#会踢足球的人员和会打篮球的人员
#使用set并集的方式,输出两类总共人数 f_s = set(football) #将football转换为f_s集合
b_s = set(basketball) #将basketball转换为b_s集合 print(f_s,b_s)
print(f_s.union(b_s)) #取f_s和b_s的交集 #{'王五', '张三', '李四'} {'赵六', '张三', '王五'}
#{'赵六', '张三', '李四', '王五'}
union()
3.difference()差集
football = ['张三','李四','王五']
basketball = ['张三','王五','赵六'] f_s = set(football) #将football转换为f_s集合
b_s = set(basketball) #将basketball转换为b_s集合 print('差集1',f_s - b_s) #f_s.difference(b_s) 等同于 f_s - b_s
print(f_s.difference(b_s)) print('差集2',b_s - f_s) #b_s.difference(f_s) 等同于 b_s - f_s
print(b_s.difference(f_s)) #差集1 {'李四'}
#{'李四'}
#差集2 {'赵六'}
#{'赵六'}
difference()
4.symmetric_difference() 交叉补集
football = ['张三','李四','王五']
basketball = ['张三','王五','赵六'] f_s = set(football) #将football转换为f_s集合
b_s = set(basketball) #将basketball转换为b_s集合 print(f_s.symmetric_difference(b_s)) #f_s.difference(b_s) 等同于 f_s ^ b_s #{'李四', '赵六'}
symmetric_difference()
PS:这几类方法后面加.update是求完值之后重新赋值
5.isdisjoint issubset issuperset
判断有无交集 判断是否是子集 判断是否是父集
6.update
更新多个值 和add不同的是 add只能添加单个值
s = {'s','g','h'}
s.update('e','n',(10,1),[22,33],{50:2,30:4})
print(s)
#字符串和所有可迭代对象都可以被update添加
#{1, 33, 'e', 10, 's', 50, 22, 'g', 'h', 30, 'n'}
字符串的格式化
一、常用格式化
%字符的用处
msg = 'i am %s my hobby is %s' % ('even','python')
print(msg)
#i am even my hobby is python
msg1 = 'i am %s my hobby is %s' % ('even',123)
msg2 = 'i am %s my hobby is %s' % ('even',[1,2])
print(msg1)
print(msg2)
#i am even my hobby is 123
#i am even my hobby is [1,2]
打印浮点数
tpl = "percent %.2f" % 99.976238888 #.2f保留浮点数后两位
print(tpl)
#percent 99.98
打印百分比
tpl = 'percent %.2f %%' % 99.976238888
print(tpl)
#percent 99.98 %
:分隔符拼接
print('root','x','','',sep=':')
#root:x:0:0
二、format 的常用格式化
tpl = "i am {}, age {}, {}".format("seven", 18, 'alex') tpl = "i am {}, age {}, {}".format(*["seven", 18, 'alex']) tpl = "i am {0}, age {1}, really {0}".format("seven", 18) tpl = "i am {0}, age {1}, really {0}".format(*["seven", 18]) tpl = "i am {name}, age {age}, really {name}".format(name="seven", age=18) tpl = "i am {name}, age {age}, really {name}".format(**{"name": "seven", "age": 18}) tpl = "i am {0[0]}, age {0[1]}, really {0[2]}".format([1, 2, 3], [11, 22, 33]) tpl = "i am {:s}, age {:d}, money {:f}".format("seven", 18, 88888.1) tpl = "i am {:s}, age {:d}".format(*["seven", 18]) tpl = "i am {name:s}, age {age:d}".format(name="seven", age=18) tpl = "i am {name:s}, age {age:d}".format(**{"name": "seven", "age": 18}) tpl = "numbers: {:b},{:o},{:d},{:x},{:X}, {:%}".format(15, 15, 15, 15, 15, 15.87623, 2)
#进制互转格式化 tpl = "numbers: {:b},{:o},{:d},{:x},{:X}, {:%}".format(15, 15, 15, 15, 15, 15.87623, 2) tpl = "numbers: {0:b},{0:o},{0:d},{0:x},{0:X}, {0:%}".format(15) tpl = "numbers: {num:b},{num:o},{num:d},{num:x},{num:X}, {num:%}".format(num=15)
**代表字典对应格式化
tpl = "i am {name:s}, age {age:d}".format(**{"name": "seven", "age": 18})
print(tpl)
*代表列表对应格式化
tpl = "i am {:s}, age {:d}".format(*["seven", 18])
print(tpl)
Python基础 之 set集合 与 字符串格式化的更多相关文章
- 14.python类型总结,集合,字符串格式化
借鉴:https://www.cnblogs.com/linhaifeng/articles/5935801.html https://www.cnblogs.com/wupeiqi/article ...
- python学习6—数据类型之集合与字符串格式化
python学习6—数据类型之集合与字符串格式化 1. 使用id()可以查看一个变量的内存地址: name = 'alex' id(name) 2. 进制转换 十进制转换为二进制等: a = 10 # ...
- 『Python基础-11』集合 (set)
# 『Python基础-11』集合 (set) 目录: 集合的基本知识 集合的创建 访问集合里的值 向集合set增加元素 移除集合中的元素 集合set的运算 1. 集合的基本知识 集合(set)是一个 ...
- Python基础数据类型之集合
Python基础数据类型之集合 集合(set)是Python基本数据类型之一,它具有天生的去重能力,即集合中的元素不能重复.集合也是无序的,且集合中的元素必须是不可变类型. 一.如何创建一个集合 #1 ...
- Python基础篇(set集合)
Python基础篇(set集合,深浅拷贝) set集合是Python的一个基本类型,一般是不常用.set中的元素是不重复的.无序的里边 的元素必须是可hash的比如int,str,tuple,bool ...
- 【笔记】Python基础二:数据类型之集合,字符串格式化,函数
一,新类型:集合 集合出现之前 python_l = ['lcg','szw','zjw'] linux_l = ['lcg','szw','sb'] #循环方法求交集 python_and_linu ...
- Python系列之模块、和字符串格式化
Python 模块 模块让你能够有逻辑地组织你的Python代码段. 把相关的代码分配到一个 模块里能让你的代码更好用,更易懂. 模块也是Python对象,具有随机的名字属性用来绑定或引用. 模块分为 ...
- python关键字、转义符和字符串格式化
最近在学learn python the hard way,学习到第37章,进行了关于关键字.转义符和字符串格式化的总结.看手头上的中文版没有及时更新.于是就把这些翻译过来,以作查阅. 关键字: 关键 ...
- python_05 可变类型与不可变类型、集合、字符串格式化
可变数据类型与不可变数据类型: 1.可变:列表,字典 2.不可变:字符串,数字,元组 访问顺序: 1.顺序访问:字符串,列表,元组 2.映射:字典 集合 由不同元素组成的集合,集合中是一组无序排列的可 ...
随机推荐
- Python:文件的读取、创建、追加、删除、清空
一.用Python创建一个新文件,内容是从0到9的整数, 每个数字占一行:#python>>>f=open('f.txt','w') # r只读,w可写,a追加>> ...
- Sublime text3学习小记(macOS系统下的安装使用)
[注:以下内容参考https://blog.csdn.net/stilling2006/article/details/54376743] 一.认识Sublime text 1.一款跨平台代码编辑器, ...
- 一点一点看JDK源码(五)java.util.ArrayList 后篇之Spliterator多线程遍历
一点一点看JDK源码(五)java.util.ArrayList 后篇之Spliterator多线程遍历 liuyuhang原创,未经允许禁止转载 本文举例使用的是JDK8的API 目录:一点一点看J ...
- Mongodb使用命令总结
使用时的Mongodb版本为:3.2 1.导出: mongoexport --host mongodb1.example.net --port 37017 --username user --pass ...
- iOS:UICollectionView流式布局及其在该布局上的扩展的线式布局
UICollectionViewFlowLayout是苹果公司做好的一种单元格布局方式,它约束item的排列规则是:从左到右依次排列,如果右边不够放下,就换一行重复上面的方式排放,,,,, 常用的 ...
- Mysql 之 MERGE 存储引擎
MERGE 存储引擎把一组 MyISAM 数据表当做一个逻辑单元来对待,让我们可以同时对他们进行查询.构成一个 MERGE 数据表结构的各成员 MyISAM 数据表必须具有完全一样的表结构.每一个成员 ...
- ComboBox可搜索下拉框的使用注意事项,简单记录以及我遇到的一些奇怪的bug
前几天做一个react的项目的时候需要用一个可搜索的下拉框ComboBox,上代码: <ComboBox // className={comboxClassName} items={storeA ...
- Linux中JDK的安装步骤
1.下载jdk安装包rpm格式安装 http://download.oracle.com/otn-pub/java/jdk/8u131-b11/d54c1d3a095b4ff2b6607d096fa8 ...
- 如何快速生成数据库字典(thinkphp5.0)
本教程将教你快速生成数据库字典 示例代码使用PHP框架:Thinkphp5.0 PHP代码: /** * 生成数据库字典html * 可直接另存为再copy到word文档中使用 * * @return ...
- STM32(9)——通用定时器作为输入捕捉
通用定时器作为输入捕获的使用.我们将用 TIM5 的通道 1 (PA0)来做输入捕获,捕获 PA0 上高电平的脉宽(用 WK_UP 按键输入高电平),通过串口打印高电平脉宽时间 输入捕获简介 输入捕获 ...