补充:enumerate 函数用于遍历序列(元组tuple、列表list、字典dict)中的元素以及它们的下标:

>>> for i,j in enumerate(('a','b','c')):
      print(i,j,end="")
0 a1 b 2c

Python 集合set

定义:由不同元素组成的无序的元组    形式:S = {'H','E','L','L','O'}或者S = set('HELLO')

set()函数可以把列表、元组等等转换为集合     集合可以做到简单去重的效果,也可以进行交差并等的集合运算。

集合的内置方法:

#add方法:把元素添加到集合
s = {1,2,4,5}
s.add('3')

#clear方法:清空集合
s.clear()

#copy拷贝
s1 = s.copy()

#pop方法:随机删除一个值
s = {1,2,3,4,5}
s.pop()

#remove方法:指定删除,删除元素不存在会报错
s = {1,2,3,4,5,'hello'}
s.remove('hello')

#discard方法:指定删除,删除元素不存在不会报错
s = {1,2,3,4,5,'hello'}
s.discard('hello')

集合的运算:交、并、差

#求交集   2个方法:intersection 或 &
Linux = ['a',1,2,3,'b']
Python = ['a',5,3,6,4,'c']
linux_s = set(Linux)
python_s = set(Python)
print(python_s.intersection(linux_s))
print(python_s & linux_s)

#求并集 2个方法:union 或 | Linux = ['a',1,2,3,'b'] Python = ['a',5,3,6,4,'c'] a = set(Linux) b = set(Python) print(a.union(b)) print(a | b) #求差集 2个方法:difference 或 -(减号) Linux = ['a',1,2,3,'b'] Python = ['a',5,3,6,4,'c'] a = set(Linux) b = set(Python) print(b-a) print(a-b) print(b.difference(a)) #b集合减去a集合 print(a.difference(b)) #a集合减去b集合
a.difference_update(b)  #a集合减去b集合并更新a集合,与上面作用没什么大的区别
 

#交差补集:两集合并到一起,之后减去两个共有的元素

#求交叉补集 两种方法:symmetric_difference() 或 ^
Linux = ['a',1,2,3,'b']
Python = ['a',5,3,6,4,'c']
a = set(Linux)
b = set(Python)
print(a.symmetric_difference(b))
print(a ^ b)

集合运算补充:

#isdisjoint方法:如果两个集合的交集不存在则为True,否则False
print(linux_s.isdisjoint(python_s))

#issubset()方法:如果s1是s2的子集,返回True
print(s1.issubset(s2))
#issuperset()方法:如果s1是s2的父集,返回True
print(s1.issuperset(s2))

#update更新,add只能添加一个值,而update可用于更新多个值(包括列表元组等等)
s1 = {1,2}
s2 = {1,2,3}
s1.update(s2)     ==========>{1,2,3}

#symmetric_difference_update方法:与symmetric_difference()交叉补集几乎相同

#intersection_update:与交集几乎相同

集合是可变的,定义不可变集合:s = frozenset()

不可变集合没有add、remove等等的方法。

 

字符串拼接  注意:拼接字符串时不可以把字典与%d / %s同时使用,否则会报错

msg = 'my hobby is alex' + '1hf'   #用加号拼接,但是效率低,一般不用。
print(msg) 

#%s代表字符串,可以接收多个任意类型值,他是万能的,包括列表。
s前面可以加数值代表截取的长度 例如 .3s 代表3的单位长度的字符
msg = 'I am %s my hobby is alex'  %'xut'
print(msg)     =====>> I am xut my hobby is alex

name = 'lhf'
age = 19
msg = 'i am %s my hobby is %d' %(name,age)

#%d只可以接收整型数字,%f 代表浮点型,%.2f保留2位浮点数,并进行四舍五入
#打印百分比,2个%
tpl = 'percent %.2f %%'  %99.999
print(tpl)       =====>> percent 100.00%

#字典键值对的引用,%(keys)s/d    s是字符串d是整型
tpl = 'i am %(name)s age %(age)d' %{"name":'alex',age:18} 

#加号是右对齐指定长度(包括name的值),减号左对齐指定长度(包括name的值)
tpl = 'i am %(name)-60s my hobby is alex' %{"name":lhf}
print(tpl)      ======>> i am lhf                                              my hobby is alex

print输出时的分割符用sep指定

print('root ','x','0',sep=':')            ====>>  root:x:0

format字符串格式化

#format的一般用法,大括号内数字是索引号
tpl = "i am {2},age {1},{0}".format("seven",18,'alex')
print(tpl)     =======>>i am alex,age 18 ,seven

tpl = "i am {1},age {1}"
print(tpl)     ======>>i am 18,age 18

#字典传值的两种方式,键keys 传值
方法一:
tpl = "i am {name},age {age}'".format(name="alex“,age=18)
方法二:使用两个*,加上字典。
tpl = "i am {name},age {age}".format(**{"name":'alex',"age":18})

#列表传值时使用{索引号[列表索引号]}
tpl = "i am {0[0]},age {1[1]}".format(["seven"],[18,'alex'])

#{:S}代表传值的类型是字符串型 {:d}代表传值的类型是整型 {:f}代表传值的类型是浮点型
tpl = "i am {:s},age {%d},{%f}“.format("alex",18,2.11)

#*星号代表传入的只是一个列表
tpl = "i am {:s},age {:d}".format(*["seven",18])
m = ["seven",18]
tpl = "i am {:s},age {:d}".format(*m)

#:b二进制  :d整型 :o八进制 :x小写的16进制 :X大写的16进制  :%显示百分比
tpl = "{%o},{:%}“.format(15,15)
print(tpl)    =======>>17 15%

 

posted on 2019-02-19 22:07  Miracle&Hat  阅读(192)  评论(0编辑  收藏  举报