集合的格式
变量名=set()
变量名.add(元素)
# 必须不能初始化值
一、集合
1.1 集合的特征
集合是无序的,集合中的元素是唯一的,集合一般用于元组或者列表中的元素去重
1.2 集合的格式
格式
变量名=set()
变量名.add(元素)
# 必须不能初始化值
或
变量名={元素,元素,,,}
注意:下面写法为一个空字典,为空默认是字典,如果有数据在根据格式判断为字典还是集合
name={}
1.3 添加元素
1.3.1 add
nums = {11,24,45,96,28}
nums.add(42)
print(nums)
#{96, 42, 11, 45, 24, 28}
1.3.2 update
nums = {11,24,45,96,28}
nums2=["anfly","tom"]
nums.update(nums2)
print(nums)
#{96, 'anfly', 11, 45, 24, 28, 'tom'}
1.4:删除元素
remove,pop,discard
1.4.1 remove
使用remove删除集合中的元素 如果有直接删除 如果没有程序报错
案例:该元素存在
nums = {11,24,45,96,28}
nums.remove(24)
print(nums)
#{96, 11, 45, 28}
案例:该元素不存在
nums = {11,24,45,96,28}
nums.remove(245)
print(nums)
#KeyError: 245
1.4.2 pop
1、如果集合的元素都是数字, 删除时, 删掉的是最小的数字, 其余数字升序排列
2、如果集合的元素是非数字, 删除时, 删掉的是随机的元素, 其余元素随机排列
3、如果集合里既有数字又有非数字元素, 删除时:
若删掉的是数字, 则一定是删掉了最小的, 其他数字升序排列, 非数字元素随机排列;
若删掉的非数字, 则一定是随机删掉了一个, 其他数字升序排列, 非数字则随机排列.
如果集合没有元素程序报错
案例:有元素
nums = {11,24,45,96,28}
nums.pop()
print(nums)
#{11, 45, 24, 28}
案例:无元素
nums = {}
nums.pop()
print(nums)
#TypeError: pop expected at least 1 arguments, got 0
1.4.3 discard
使用discard删除 如果元素存在直接删除 如果元素不存在不做任何操作
案例:该元素存在
nums = {11,24,45,96,28}
nums.discard(24)
print(nums)
#{96, 11, 45, 28}
案例:该元素不存在
nums = {11,24,45,96,28}
nums.discard(242)
print(nums)
#{96, 11, 45, 24, 28}
1.5:集合的交集和并集
1.5.1:交集
使用&连接多个集合,得到相同的元素
案例:存在相同元素
set1 = {"anfly","tom","haha"}
set2 = {"anfly","susala"}
set3= set1 & set2
print(set3)
返回值:{'anfly'}
案例:存在相同元素
set1 = {"anfly","tom","haha"}
set2 = {"anfly2","susala"}
set3= set1 & set2
print(set3)
返回值:set()
1.5.2:并集
使用|连接多个集合,得到全部集合中全部的元素
案例:
set1 = {1, 2, 3, 4}
set2 = {3, 4, 5, 6}
new_set = set1 | set2
print(new_set)
#{1, 2, 3, 4, 5, 6}
什么是函数
在开发程序时,需要某块代码多次,但是为了提高编写的效率以及代码的重用,所以把具有独立功能的代码块组织为一个小模块,这就是函数
2.2 函数定义和调用
格式
def 函数名():
执行语句
函数名() #调用函数
案例
def hello():
print("hello word")
hello()
注意:
定义了函数之后,就相当于有了一个具有某些功能的代码,想要让这些代码能够执行,需要调用它
调用函数很简单的,通过 函数名() 即可完成调用
每次调用函数时,函数都会从头开始执行,当这个函数中的代码执行完毕后,意味着调用结束了
当然了如果函数中执行到了return也会结束函数
2.3 函数参数
思考:现在需要定义一个函数,这个函数能够完成2个数的加法运算,并且把结果打印出来,该怎样设计?
案例
def add2num():
a = 11
b = 22
c = a+b
print c
思考:如果为了让一个函数更通用,即想让它计算哪两个数的和,就让它计算哪两个数的和,在定义函数的时候可以让函数接收数据?
引入:参数传递
2.3.1:位置参数
格式
def 函数名(参数1,参数2):
代码块
函数名(值1,值2)
案例:
def fun(a,b):
print("a:",a)
print("b:",b)
fun(2,3)
结果:a: 2 b:3
小总结
定义时小括号中的参数,用来接收参数用的,称为 “形参”
调用时小括号中的参数,用来传递给函数用的,称为 “实参”
2.3.2 关键字参数
格式
def 函数名(参数1,参数2):
代码块
函数名(参数1=值1,参数2=值2)
案例:
def fun(a,b):
print("a:",a)
print("b:",b)
fun(a=2,b=3)
结果:a: 2 b:3
注意:参数调用时,可以改变传参顺序,如果有位置参数需要位置参数放在关键字参数前面
案例:
def fun(a,b):
print("a:",a)
print("b:",b)
fun(3,b=2)
结果:a: 3 b:2
如果关键字参数传参要在位置参数之前,将会报错
案例:错误
def fun(a,b):
print("a:",a)
print("b:",b)
fun(a = 3,2)
#SyntaxError: positional argument follows keyword argument
2.3.3:缺省参数
在形参中默认有值的参数,称之为缺省参数
案例:调用函数时,缺省参数的值没有传入
def printinfo(name,age=20):
print("name:",name)
print("age:",age)
printinfo(name="anfly")
#name: anfly
#age: 20
案例:调用函数时,缺省参数的值传入
def printinfo(name,age=20):
print("name:",name)
print("age:",age)
printinfo(name="anfly",age=10)
#name: anfly
#age: 10
案例
def printinfo(age=20,name):
print("name:",name)
print("age:",age)
printinfo(name="anfly",age=10)
#SyntaxError: non-default argument follows default argument
总结
调用函数时,缺省参数的值如果没有传入,则取默认值(形式参数),如果传入,则取实际参数
缺省参数一定要位于位置参数的最后面
2.3.4 不定长参数
有时可能需要一个函数能处理比当初声明时更多的参数, 这些参数叫做不定长参数,声明时不会命名。
格式
def printinfo(*args,**kwargs):
print("args:",args)
print("kwargs:",kwargs)
printinfo(参数)
注意:加了星号(*)的变量args会存放所有未命名的变量参数,args为元组
而加**的变量kwargs会存放命名参数,即形如key=value的参数, kwargs为字典
案例:不定长参数* args
def printinfo(*args):
print("args:",args)
printinfo(100,200,300,400)
#args: (100, 200, 300, 400)
案例:* args不能接收key=value类型的参数
def printinfo(*args):
print("args:",args)
printinfo(100,200,300,b = 400)
#TypeError: printinfo() got an unexpected keyword argument 'b'
案例:不定长参数* * kwargs
def printinfo(**kwargs):
print("kwargs:",kwargs)
printinfo(a=100,b=200,c=300,d= 400)
#kwargs: {'a': 100, 'b': 200, 'c': 300, 'd': 400}
案例:* * kwargs不能接收未命名的变量参数
def printinfo(**kwargs):
print("kwargs:",kwargs)
printinfo(100,b=200,c=300,d= 400)
#TypeError: printinfo() takes 0 positional arguments but 1 was given
2.3.5:参数位置顺序
格式
def fun(位置参数,*args,缺省参数,**kwargs):
代码块
fun(参数值)
案例
def sun(a,*args,b=22,**kwargs):
print("a:",a)
print("args:",args)
print("b:",b)
print("kwargs:",kwargs)
sun(100,200,300,b=2,m=3,n=4)
返回值:
a: 100
args: (200, 300)
b: 2
kwargs: {'m': 3, 'n': 4}
注意:•如果很多个值都是不定长参数,那么这种情况下,可以将缺省参数放到 *args的后面, 但如果有**kwargs的话,**kwargs必须是最后的
2.4:函数返回值
场景:•我给儿子10块钱,让他给我买包烟。这个例子中,10块钱是我给儿子的,就相当于调用函数时传递到参数,让儿子买烟这个事情最终的目标是,让他把烟给你带回来然后给你对么,,,此时烟就是返回值
格式
def sum():
代码块
return 值
sum()
代码
def sum(a,b):
return a+b
sum(1,2)
代码:查看返回值
def sum(a,b):
return a+b
result = sum(1,2) #保存函数的返回值
print(result)
2.4.1:多个return
def create_nums(num):
print("---1---")
if num == 100:
print("---2---")
return num+1 # 函数中下面的代码不会被执行,因为return除了能够将数据返回之外,还有一个隐藏的功能:结束函数
print("return执行之后不会继续执行")
print(“1231223")
else:
print("---3---")
return num+2
print("---4---")
result1 = create_nums(100)
print(result1) # 打印101
result2 = create_nums(200)
print(result2) # 打印202
注意:一个函数中可以有多个return语句,但是只要有一个return语句被执行到,那么这个函数就会结束了,因此后面的return没有什么用处
2.4.2:返回多个数据
代码
def divid(a, b):
shang = a//b #取模
yushu = a%b #取余
return shang, yushu #默认是元组
result = divid(5, 2)
print(result)
# 输出(2, 1)
总结:return后面可以是元组,列表、字典等,只要是能够存储多个数据的类型,就可以一次性返回多个数据
2.5:函数类型
分类:
1. 无参数,无返回值
2. 无参数,有返回值
3. 有参数,无返回值
4. 有参数,有返回值
2.5.1:无参数,无返回值的函数
此类函数,不能接收参数,也没有返回值,一般情况下,打印提示灯类似的功能,使用这类的函数
def printMenu():
print('--------------------------')
print(' xx涮涮锅 点菜系统')
print('')
print(' 1. 羊肉涮涮锅')
print(' 2. 牛肉涮涮锅')
print(' 3. 猪肉涮涮锅')
print('--------------------------')
2.5.2:无参数,有返回值的函数
•此类函数,不能接收参数,但是可以返回某个数据,一般情况下,像采集数据,用此类函数
def getTemperature():
# 这里是获取温度的一些处理过程
# 为了简单起见,先模拟返回一个数据
return 24
2.5.3:有参数,无返回值的函数
•此类函数,能接收参数,但不可以返回数据,一般情况下,对某些变量设置数据而不需结果时,用此类函数
2.5.4:有参数,有返回值的函数
•此类函数,不仅能接收参数,还可以返回某个数据,一般情况下,像数据处理并需要结果的应用,用此类函数
2.6:函数的嵌套
一个函数里面又调用了另外一个函数,这就是所谓的函数嵌套调用
案例
def testb():
print("testb start")
print("testb testb 执行")
print("testb end")
def testa():
print("testa start")
testb()
print("testa end")
返回值
testa start
testb start
testb testb 执行
testb end
testa end
如果函数A中,调用了另外一个函数B,那么先把函数B中的任务都执行完毕之后才会回到上次 函数A执行的位置
# 打印一条横线
def printOneLine():
print("-"*30)
# 打印多条横线
def printNumLine(num):
i=0
# 因为printOneLine函数已经完成了打印横线的功能,
# 只需要多次调用此函数即可
while i<num:
printOneLine()
i+=1
printNumLine(3)