定义函数
- 认识函数:
1)什么是函数:函数就是实现某一个特定功能的代码的封装(每个函数都有子集特定的功能)
函数就是把实现某一个功能的所有的代码达成了一个包,每次需要这个功能的时候不同再重复去写实现这个功能的代码了,而是使用函数
2)函数的分类(按照函数是由谁创建/定义来进行的分类)
系统函数 - 由python定义的函数,这类函数只需要在需要它的功能的时候去调用它(系统已经造好的机器)
例如:print、input、type、id、max、min、sum等…
自定义函数 - 由程序员自己创建自己使用的函数(自己造的机器)
- 定义(创建)函数 - 造机器
语法:
def 函数名(形参列表):
函数说明文档
函数体
说明:
def - 固定写法
函数名 - 程序员自己命名
两个要求:是标识符;不是关键字
三个规范:见名知义(看到函数大概知道函数的功能)、字母都小写多个单词之间用下划线隔开;不使用系统的函数名、类名、和模块名
(): - 固定写法
形参列表 - 格式:使用多个变量名用逗号隔开,其中一个变量表示一个形参。(也可以没有形参)
形参的作用:将函数外部的数据传递函数里面
函数说明文档 - 本质就是一个多行注释(相当于机器的说明)
函数体 - 就是和def保持一个缩进的一条或者多条语句。就是实现函数功能的代码
- 初学者定义函数的基本步骤
第一步:确定函数的功能(确定机器造出来是干嘛用的)
第二步:根据功能确定函数名(给机器取名字)
第三步:确定形参;看看实现函数的共嗯那个需不需要额外的数据,需要几个
第四步:利用形参提供的数据实现函数功能
第五步:顶顶返回值(先不看)
第六步:写函数说明文档
# 练习1:定义一个函数求两个数的和
def sum1(x, y):
k = x + y
return k
print(sum1(1, 2))
# 练习2:定义一个函数获取指定整数的个位数
def gewei(x):
y = x % 10
return y
print(gewei(123))
# 练习3:定义一个函数获取指定字符串中数字字符的个数
def num(x):
count = 0
for n in x:
if '0' <= n <= '9':
count += 1
return count
print(num('1234'))
# 练习4:定义一个函数将两个字符串合并成一个字符串,合并方式如下:
def mix_str(str1, str2):
len1 = len(str1)
len2 = len(str2)
# length = len1 if len1 < len2 else len2
length = min(len1, len2)
new_str = ''
for index in range(length):
new_str += str1[index] + str2[index]
new_str += str1[length:]+str2[length:]
print(new_str)
- 调用函数(使用机器)
定义函数的时候不会执行函数体,调用函数才会执行函数体(机器造好以后不用机器的功能就无法体现)
语法:
函数名(实参列表)
说明:
函数名 - 需要调用的函数的函数名(这个函数名对应的函数必须是已经定义好的函数)
() - 固定写法
实参列表 - 格式:多个数据用逗号隔开
实参是用来给形参赋值(实参就是通过形参爨地到函数内容的数据)
1)调用多少次,函数体就会执行多少次
2)调用函数的时候,实参的个数由被调用的额函数的形参决定(用实参给形参赋值的过程叫传参)
3)函数调用过程(简单版)
当代码执行到函数调用语句的时候,后面的执行过程如下:
第一步:回到函数定义的位置
第二步:传参(用实参给形参赋值)
第三步:执行函数体
第四步:确定返回值
第五步:返回函数调用的位置,接着往后执行
函数的参数
- 位置参数和关键字参数
根据调用函数的时候实参提供方式的不同,将实参分为位置参数和关键字参数两种
1)位置参数
直接提供实参对应的数据,让实参和形参在位置上一一对应
def func1(a, b, c):
print(f'a:{a},b:{b},c:{c}')
func1(100, 200, 300) # a:100,b:200,c:300
func1(200, 100, 300) # a:200,b:100,c:300
2)关键字参数
以’形参1 = 实参1, 形参2 = 实参2…'的形式传参
func1(b=200, c=300, a=100) # a:100,b:200,c:300
3)混用
位置参数和关键字参数可以一起,一起用的时候必须保证位置参数在关键字参数的前面
func1(10, b=20, c=30)
- 参数默认值
定义函数的时候可以以’形参名 = 值’的形式给形参提供默认值;
如果一个参数有默认值,那么在调用函数的时候有默认值的参数可以不用传参
如果定义函数的时候有的参数有默认值,有的参数没有,那么没有参数默认值的参数必须在有默认值的参数前面
def func2(a=10, b=20, c=30):
print(f'a:{a},b:{b},c:{c}')
func2() # a:10,b:20,c:30
func2(100) # a:100,b:20,c:30
func2(100, 200) # a:100,b:200,c:30
func2(100, 200, 300) # a:100,b:200,c:300
func2(c=300) # a:10,b:20,c:300(跳过前面有默认值的参数,给后面的参数传参使用关键参数)
- 参数类型说明
有默认值的参数:默认值是什么类型,类型说明就是什么类型
没有默认值的参数:需要在形参后加’:类型名’
-
不定长参数
1)带的不定长参数 - 如果在一个形参前加,那么这个形参就可以接受任意多个实参
带*的不定长参数的本质就是一个元组,对应的多个实参是元组中的元素
注意:a.带*的不定长参数,传参的时候必须使用位置参数
b.如果定长参数在带*的参数后面(有的时候是直接在*****的后面),那么后面的定长参数调用的时候必须用关键字参数传参
2)带**的不定长参数
def func9(**x): pass print(x) # {'a': 10, 'b': 20} func9(a=10, b=20)
返回值
- 返回值的作用
返回值的作用就是将函数内部产生的数据,传递到函数的外部
初学者怎么确定函数需不需要返回值:看函数的功能有没有产生新的数据,如果有就将新的数据作为返回值返回
- 确定函数的返回值(怎么将数据作为返回值)
在函数体中通过return关键字返回函数的返回值:return 数据
注意:1)如果执行函数体的时候没有遇到return,哈桑农户的返回值是None
2)return还具有提前结束函数的功能(执行函数体的时候在哪儿遇到return,函数在哪儿结束)
- 怎么在函数外面获取函数的返回值
获取函数调用表达式的值就是获取函数的返回值
函数调用表达式 - 调用函数的语句
每一个函数调用语句其实都有一个结果(都是一个数据),这个结果就是这次调用的时候函数的返回值
一个函数的返回值是什么,就看调用函数的时候return后面的值是什么,return后面的值是什么,函数外部函数调用表达式就是什么
作业
-
编写一个函数,交换指定字典的key和value。
例如:dict1={'a':1, 'b':2, 'c':3} --> dict1={1:'a', 2:'b', 3:'c'}
def exchange(x:dict): new_dict = {x[i]: i for i in x} return new_dict print(exchange({'a': 1, 'b': 2, 'c': 3})) # {1: 'a', 2: 'b', 3: 'c'}
-
编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串
例如: 传入'12a&bc12d-+' --> 'abcd'
def ping(x:str): new_str = '' for i in x: if 'a'<= i <= 'z' or 'A'<= i <= 'Z': new_str += i return new_str print(ping('12a&bc12d-+'))
-
写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母
例如: 'abc' -> 'Abc' '12asd' --> '12asd'
def capitalize(x:str): new_str = x[0].upper() + x[1:] return new_str print(capitalize('abc'))
-
写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束
例如: 字符串1:'abc231ab' 字符串2:'ab' 函数结果为: True 字符串1:'abc231ab' 字符串2:'ab1' 函数结果为: False
def endswith(x: str, y: str): if x[len(x)-len(y):] == y: return True else: return False print(endswith('abc231ab', 'ab')) # True print(endswith('abc231ab', 'ab1')) # False
-
写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串
例如: '1234921' 结果: True '23函数' 结果: False 'a2390' 结果: False
print(isdigit('1234921')) # True print(isdigit('23函数')) # False print(isdigit('a2390')) # False
-
写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母
例如: 'abH23好rp1' 结果: 'ABH23好RP1'
def upper(x: str): new_str = '' for i in x: if 'a' <= i <= 'z': new_str += chr(ord(i)-32) else: new_str += i return new_str print(upper('abH23好rp1')) # ABH23好RP1
-
写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充
例如: 原字符:'abc' 宽度: 7 字符:'^' 结果: '^^^^abc' 原字符:'你好吗' 宽度: 5 字符:'0' 结果: '00你好吗'
def rjust(x, y: str, z: str): ''' x - 长度 y - 原字符串 z - 插入的字符 ''' new_str = (x-len(y)) * z + y return new_str print(rjust(7, 'abc', '^')) # ^^^^abc
-
写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1
例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0] 元素: 1 结果: 0,4,6 列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '赵云' 结果: 0,4 列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '关羽' 结果: -1
def index(x: list, y): count = 0 new_list = [] for i in range(len(x)): if x[i] == y: new_list.append(i) count += 1 if count == 0: return -1 else: return new_list print() list1 = [1, 2, 45, 'abc', 1, '你好', 1, 0] list2 = ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] print(index(list1, 1)) # [0, 4, 6] print(index(list2, '关羽')) # -1
-
写一个自己的len函数,统计指定序列中元素的个数
例如: 序列:[1, 3, 5, 6] 结果: 4 序列:(1, 34, 'a', 45, 'bbb') 结果: 5 序列:'hello w' 结果: 7
def len(x): count = 0 for i in x: count += 1 return count print(len([1, 3, 5, 6])) # 4 print(len((1, 34, 'a', 45, 'bbb'))) # 5 print(len('hello w')) # 7
-
写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值
例如: 序列:[-7, -12, -1, -9] 结果: -1 序列:'abcdpzasdz' 结果: 'z' 序列:{'小明':90, '张三': 76, '路飞':30, '小花': 98} 结果: 98
def max1(x): if type(x) == dict: return max(x.values()) else: return max(x) print(max1([-7, -12, -1, -9])) # -1 print(max1('abcdpzasdz')) # z print(max1({'小明': 90, '张三': 76, '路飞': 30, '小花': 98})) # 98
-
写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在
例如: 序列: (12, 90, 'abc') 元素: '90' 结果: False 序列: [12, 90, 'abc'] 元素: 90 结果: True
def in1(x, y): for i in x: if i == y: return True else: return False print(in1((12, 90, 'abc'), '90')) # False print(in1([12, 90, 'abc'], 90)) # True
-
写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串
例如: 原字符串: 'how are you? and you?' 旧字符串: 'you' 新字符串:'me' 结果: 'how are me? and me?'
def replace(x,y,z):
new_str = ''
i = 0
while i < len(x):
if x[i] == y[0]:
if x[i:i+len(y)] == y:
new_str += z
i += len(y)-1
else:
new_str += x[i]
else:
new_str += x[i]
i += 1
return new_str
print(replace('how are you? and you?', 'you', 'me')) # how are me? and me?