Python 函数基础
一、认识函数
- 函数的概念:函数是对实现某一特定功能的代码的封装
- 函数的分类
- 系统函数:Python这门语言所提供的函数
- 自定义函数:自己编写的函数
二、定义函数
-
语法
def 函数名(形参列表): 函数说明文档 函数体
-
说明
- def - 固定写法
- 函数名 - 自己命名
- 要求:标识符;不是关键字;尽量不要与系统函数重复
- 规范:见名知意;字母都小写;单词间用’_'连接
- () - 固定写法
- 形参列表
- 格式:使用多个变量名时需要用逗号隔开
- 作用:将函数外的参量传递到函数内
- 函数说明文档 - 本质是一个多行注释,相当于一个说明书
- 函数体 - 与def保持一个缩进,函数实现功能的代码都在这一部分
-
步骤
- 确定函数的功能
- 命名
- 确定形参,初学者可以先写函数体,最后返回来确定形参
- 利用形参在函数内部实现功能
- 确定返回值
- 书写说明文档
# example 定义一个函数获取指定字符串中数字字符的个数
def nums_count(string):
count = 0
for i in string:
if '0' <= i <= '9':
count += 1
return count
# example 实现合并
def str_sum(string1, string2):
string1_len = len(string1)
string2_len = len(string2)
string = ''.join(string1[i] + string2[i] for i in range(min(string1_len, string2_len)))
string = ''.join(string1[i] + string2[i] for i in range(min(string1_len, string2_len)))
string += string1[string2_len:] + string2[string2_len:]
return string
三、调用函数
注意,定义函数不会执行函数体,调用函数才会执行函数体
-
语法
函数名(实参列表)
-
说明
- 函数名 - 即所要实现功能时调用的函数名
- () - 固定写法
- 实参列表 - 在实现过程中,所需使用的变量,用于给形参赋值
-
过程
当代码执行到调用函数语句时,步骤大致如下:
- 回到函数定义的位置
- 传参(实参赋值形参)
- 执行函数体
- 确定函数返回值
- 返回函数调用语句位置,继续接下来的执行
# 就之前的函数运行
count = nums_count('asdfghj9514785fw')
print('字符串中数字字符的个数:', count)
sum_str = str_sum('abc', '12345')
print(sum_str)
[Out]
字符串中数字字符的个数:7
a1b2c345
四、函数的参数
-
分类
- 位置参数 - 直接向形参赋值,实参与形参的位置需要一一对应
- 关键字参数 - 以
'形参1=实参1, 形参2=实参2, ...'
的形式向函数内部输入参量 - 混合参数 - 位置参量与关键字参量可以一起使用,但是使用时,位置参量必须放在关键字参量前面
# 位置参量 def func1(a, b, c): print(f'a:{a}, b:{b}, c:{c}') # 关键字参量 def func2(a=10, b=20, c=30): print(f'a:{a}, b:{b}, c:{c}')
-
参数默认值
- 定义函数时,可以以
'形参=值'
的形式给形参赋予默认值 - 如果一个参数有默认值,那么有默认值的参数可以不用传参
- 如果定义函数的时候有的参数有默认值,有的参数没有,那么没有默认值的参数必须放在有默认值参数的前面
def func3(a, c, b=20): print(f'a:{a}, b:{b}, c:{c}')
- 定义函数时,可以以
-
参数类型说明
- 有默认值的参数:默认值是什么类型,类型说明就是什么类型
- 没有默认值的参数:需要在形参后加
':类型名'
def func4(x:list, y=''): pass
-
不定长参量
-
带的不定长参数 - 如果在一个形参前加,那么这个形参可以接受任意多个实参
-
如果定长参数在带的参数后面(有时是直接在后面),那么后面的定长参数在调用时必须要用关键字参数
-
带 ** 的不定长参数,传参时必须使用关键字参数,带**的参数本质是一个字典
def func5(*x): print(sum(x)) def func6(*a, b, c): print(f'a:{a}, b:{b}, c:{c}') def func7(**x): print(x) def func8(*args, **kwargs): print(args, kwargs) print(sum(args) + kwargs.get('x') + kwargs.get('y')) func5(1, 2, 3, 4, 5) func6(1, 2, 3, 4, 5, b=6, c=7) func7(a=10, b=20, x=100, y=200) func8(30, 50, 70, x=10, y=10) [Out] 15 a:(1, 2, 3, 4, 5), b:6, c:7 {'a': 10, 'b': 20, 'x': 100, 'y': 200} (30, 50, 70) {'x': 10, 'y': 10} 170
-
五、函数返回值
-
作用:将函数内部产生的结果数据传递到函数外
-
确定函数的返回值
- 在函数体中是通过return关键字返回函数的返回值
如果执行函数体没有遇到return,函数的返回值是None
return具有提前结束函数的功能
def func1(num1, num2): s = num1 + num2 return s def func2(): for i in range(100): return i def func3(x): if x % 2: return 100 print('返回值:', func1(78, 90)) print('返回值:', func2()) print('返回值:', func1(20)) [Out] 返回值:168 返回值:0 返回值:None
-
获取函数返回值就是获取函数调用表达式的值
- 函数调用表达式 - 调用函数的语句
- 每一个函数调用表达式其实都有一个结果(都是一个数据),这个结果就是这次调用时函数的返回值
- 一个函数的返回值是什么,就看调用函数的时候return后面的值是什么,return后的值是什么,函数外部调用表达式的结果就是什么
练习
-
编写一个函数,交换指定字典的key和value。
例如:dict1={'a':1, 'b':2, 'c':3} --> dict1={1:'a', 2:'b', 3:'c'}
def change_key_value(dict_: dict): return {dict_[i]: i for i in dict_}
-
编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串
例如: 传入'12a&bc12d-+' --> 'abcd'
def alphabetical_struggle(str_:str): return ''.join(i for i in str_ if 'a' <= i <= 'z' or 'A' <= i <= 'Z')
-
写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母
例如: 'abc' -> 'Abc' '12asd' --> '12asd'
def capitalize(str_:str): return (chr(ord(str_[0]) - 32) if 'a' <= str_[0] <= 'z' else str_[0]) + str_[1:]
-
写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束
例如: 字符串1:'abc231ab' 字符串2:'ab' 函数结果为: True 字符串1:'abc231ab' 字符串2:'ab1' 函数结果为: False
def endswith(str_:str, end_str:str): return True if str_[-len(end_str):] == end_str else False
-
写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串
例如: '1234921' 结果: True '23函数' 结果: False 'a2390' 结果: False
def isdigit(str_:str): for i in str_: if not '0' <= i <= '9': return False else: return True
-
写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母
例如: 'abH23好rp1' 结果: 'ABH23好RP1'
def upper(str_:str): return ''.join(chr(ord(i) - 32) if 'a' <= i <= 'z' else i for i in str_)
-
写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充
例如: 原字符:'abc' 宽度: 7 字符:'^' 结果: '^^^^abc' 原字符:'你好吗' 宽度: 5 字符:'0' 结果: '00你好吗'
def rjust(str_:str, width:int, char:str): return str_ if len(str_) < width or len(char) != 1 else (width - len(str_)) * char + str_
-
写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1
例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0] 元素: 1 结果: 0,4,6 列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '赵云' 结果: 0,4 列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '关羽' 结果: -1
def index(list_:list, element): index_value = [] for i, v in enumerate(list_): if v == element: index_value.append(i) if not bool(index_value): return -1 else: return index_value
-
写一个自己的len函数,统计指定序列中元素的个数
例如: 序列:[1, 3, 5, 6] 结果: 4 序列:(1, 34, 'a', 45, 'bbb') 结果: 5 序列:'hello w' 结果: 7
def len(sequence): count = 0 for i in sequence: count += 1 return count
-
写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值
例如: 序列:[-7, -12, -1, -9] 结果: -1 序列:'abcdpzasdz' 结果: 'z' 序列:{'小明':90, '张三': 76, '路飞':30, '小花': 98} 结果: 98
def max(sequence): if type(sequence) == dict: max_num = list(sequence.values())[0] for i in sequence.values(): if i > max_num: max_num = i else: max_num = sequence[0] for i in sequence: if i > max_num: max_num = i return max_num
-
写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在
例如: 序列: (12, 90, 'abc') 元素: '90' 结果: False 序列: [12, 90, 'abc'] 元素: 90 结果: True
def in_operation(sequence, element): for i in sequence: if i == element: return True else: return False
-
写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串
例如: 原字符串: 'how are you? and you?' 旧字符串: 'you' 新字符串:'me' 结果: 'how are me? and me?'
def replace(str_:str, old_char:str, new_char:str): return new_char.join(str_.split(old_char))