数据类型的回顾与总结

可变与不可变
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集合 与 字符串格式化的更多相关文章

  1. 14.python类型总结,集合,字符串格式化

    借鉴:https://www.cnblogs.com/linhaifeng/articles/5935801.html  https://www.cnblogs.com/wupeiqi/article ...

  2. python学习6—数据类型之集合与字符串格式化

    python学习6—数据类型之集合与字符串格式化 1. 使用id()可以查看一个变量的内存地址: name = 'alex' id(name) 2. 进制转换 十进制转换为二进制等: a = 10 # ...

  3. 『Python基础-11』集合 (set)

    # 『Python基础-11』集合 (set) 目录: 集合的基本知识 集合的创建 访问集合里的值 向集合set增加元素 移除集合中的元素 集合set的运算 1. 集合的基本知识 集合(set)是一个 ...

  4. Python基础数据类型之集合

    Python基础数据类型之集合 集合(set)是Python基本数据类型之一,它具有天生的去重能力,即集合中的元素不能重复.集合也是无序的,且集合中的元素必须是不可变类型. 一.如何创建一个集合 #1 ...

  5. Python基础篇(set集合)

    Python基础篇(set集合,深浅拷贝) set集合是Python的一个基本类型,一般是不常用.set中的元素是不重复的.无序的里边 的元素必须是可hash的比如int,str,tuple,bool ...

  6. 【笔记】Python基础二:数据类型之集合,字符串格式化,函数

    一,新类型:集合 集合出现之前 python_l = ['lcg','szw','zjw'] linux_l = ['lcg','szw','sb'] #循环方法求交集 python_and_linu ...

  7. Python系列之模块、和字符串格式化

    Python 模块 模块让你能够有逻辑地组织你的Python代码段. 把相关的代码分配到一个 模块里能让你的代码更好用,更易懂. 模块也是Python对象,具有随机的名字属性用来绑定或引用. 模块分为 ...

  8. python关键字、转义符和字符串格式化

    最近在学learn python the hard way,学习到第37章,进行了关于关键字.转义符和字符串格式化的总结.看手头上的中文版没有及时更新.于是就把这些翻译过来,以作查阅. 关键字: 关键 ...

  9. python_05 可变类型与不可变类型、集合、字符串格式化

    可变数据类型与不可变数据类型: 1.可变:列表,字典 2.不可变:字符串,数字,元组 访问顺序: 1.顺序访问:字符串,列表,元组 2.映射:字典 集合 由不同元素组成的集合,集合中是一组无序排列的可 ...

随机推荐

  1. Python:文件的读取、创建、追加、删除、清空

    一.用Python创建一个新文件,内容是从0到9的整数, 每个数字占一行:#python>>>f=open('f.txt','w')    # r只读,w可写,a追加>> ...

  2. Sublime text3学习小记(macOS系统下的安装使用)

    [注:以下内容参考https://blog.csdn.net/stilling2006/article/details/54376743] 一.认识Sublime text 1.一款跨平台代码编辑器, ...

  3. 一点一点看JDK源码(五)java.util.ArrayList 后篇之Spliterator多线程遍历

    一点一点看JDK源码(五)java.util.ArrayList 后篇之Spliterator多线程遍历 liuyuhang原创,未经允许禁止转载 本文举例使用的是JDK8的API 目录:一点一点看J ...

  4. Mongodb使用命令总结

    使用时的Mongodb版本为:3.2 1.导出: mongoexport --host mongodb1.example.net --port 37017 --username user --pass ...

  5. iOS:UICollectionView流式布局及其在该布局上的扩展的线式布局

    UICollectionViewFlowLayout是苹果公司做好的一种单元格布局方式,它约束item的排列规则是:从左到右依次排列,如果右边不够放下,就换一行重复上面的方式排放,,,,,   常用的 ...

  6. Mysql 之 MERGE 存储引擎

    MERGE 存储引擎把一组 MyISAM 数据表当做一个逻辑单元来对待,让我们可以同时对他们进行查询.构成一个 MERGE 数据表结构的各成员 MyISAM 数据表必须具有完全一样的表结构.每一个成员 ...

  7. ComboBox可搜索下拉框的使用注意事项,简单记录以及我遇到的一些奇怪的bug

    前几天做一个react的项目的时候需要用一个可搜索的下拉框ComboBox,上代码: <ComboBox // className={comboxClassName} items={storeA ...

  8. Linux中JDK的安装步骤

    1.下载jdk安装包rpm格式安装 http://download.oracle.com/otn-pub/java/jdk/8u131-b11/d54c1d3a095b4ff2b6607d096fa8 ...

  9. 如何快速生成数据库字典(thinkphp5.0)

    本教程将教你快速生成数据库字典 示例代码使用PHP框架:Thinkphp5.0 PHP代码: /** * 生成数据库字典html * 可直接另存为再copy到word文档中使用 * * @return ...

  10. STM32(9)——通用定时器作为输入捕捉

    通用定时器作为输入捕获的使用.我们将用 TIM5 的通道 1 (PA0)来做输入捕获,捕获 PA0 上高电平的脉宽(用 WK_UP 按键输入高电平),通过串口打印高电平脉宽时间 输入捕获简介 输入捕获 ...