函数基础
1.定义函数
1.认识函数
1.什么是函数
函数就是实现某一特定功能的代码的封装,(每个函数都有特定的功能);函数就是把实现某一功能的代码打成一个包,每次需要这个功能的时候不用再写重复的代码,而是使用函数。
2.函数的分类(按照函数是由谁创建来分类)
- 系统函数 :由python定义的函数,这类函数只需要在需要的时候去调用即可,例如:print、input、type、id、max、min、sum、sorted等
- 自定义函数:由程序猿自己创建的自己使用的函数
2.如何定义函数
'''
语法:
def 函数名(形参列表):
函数说明文档
函数体
说明:
def - 固定写法,关键字
函数名 - 程序猿自己命名;
两个要求:是标识符;不是关键字
三个规范:见文之义;多个字母用下划线隔开;不能使用系统中的函数名,模块名,类名
() - 固定写法
形参列表 - 格式:使用多个变量名用逗号隔开,其中一个变量表示一个形参,也可以没有形参,只写()
形参的作用:将函数外部的数据传递到函数里面
函数说明文档 - 本质就是一个多行注释,相当于说明书
函数体 - 就是和def保持一个缩进的一条或者多条语句;就是实现函数功能的代码
'''
3.初学者定义函数的基本步骤
'''
第一步:确定函数的功能(确定机器造出来是干什么用的)
第二步:根据功能确定函数名
第三步:确定形参;取决于实现函数的功能需不需要额外的数据,需要几个就给定几个
第四步:利用形参数据实现函数的功能
第五步:确定返回值
第六步:写说明文档
'''
4.调用函数
'''
定义函数的时候不会执行函数体,调用函数才会执行函数体
语法:
函数名 - 定义的需要调用的函数
实参列表 - 格式:多个数据用逗号隔开,任何有结果的数据
实参是用来给形参赋值的,(实参就是通过形参传递到函数内部的数据)
调用函数的过程(简单版)
当代码执行到函数调用语句的时候,后边的执行过程如下:
第一步:回到函数定义的位置
第二步:传参
第三步:执行函数体
第四步:确定返回值(retern)
第五步:返回函数调用的位置,接着往后执行
'''
# 打印杨辉三角
def yang_hui(n):
yang = [1]
print(yang)
for x in range(n-1):
yang.append(0)
yang = [yang[y-1] + yang[y] for y in range(len(yang))]
print(yang)
# 练习1:定义一个函数求两个数的和
del sum1(num1, num2):
s = num1 + num2
# 练习2:定义一个函数获取指定整数的个位数
del ge_wei(num1):
u = num1 % 10
# 练习3:定义一个函数获取指定字符串中数字字符的个数
del str_count(str1):
count = 0
for char in str1:
if '0' <= char <= '9':
count += 1
return count
# 练习4:定义一个函数将两个字符串合并成一个字符串,合并方式如下:
# 'abc' 和 '123' 合并为:'a1b2c3'
# 'abcdef' 和 '123' 合并为:'a1b2c3def'
# 'abc' 和 '12345' 合并为:'a1b2c345'
del mix_str(str1, str2):
len1 = len(str1)
len2 = len(str2)
lenght = min(len1, len2)
for x in range(lenght):
new_str = str1[x] +str2[x]
new_str += str1[length:] + str2[length:]
return new_str
# 练习5:定义一个函数打印10的阶乘
del factorial(num=10):
for x in range(1, num+1):
pro *= x
return pro
5.形参默认值
定义函数的时候,可以以“形参名=值”的形式提供形参的默认值,存在默认值的形参,在赋值的时候可以不用赋值。当有的参数有默认值,有的参数没有默认值,定义的时候没有默认值的参数必须在有默认值的前面。
6.参数类型说明
- 有默认值的参数:默认值是什么类型,类型说明就是什么类型
- 没有默认值的参数:需要在形参后边加‘:类型名’
7.位置参数和关键字参数
根据调用函数的时候,实参提供方式的不同,将实参分为位置参数和关键字参数两种。
1)位置参数
直接提供承诺书对应的数据,让实参和形参在位置上一一对应。
2)关键字参数
以‘形参1=实参1,形参2=实参2。。。。’的形式传参
3)混用
位置参数和关键字参数可以一起,一起用的时候必须保证位置参数在关键字参数的前面。
8.不定长参数
- 带*的不定长参数:如果一个形参的前加星号,那么这种形参就可以接受任意多个吃餐;带星号的不定长参数的本质是一个元组,对应的多个实参是元组中的元素。1)带星号的不定长参数,传参的时候只能用位置参数。2)如果定长参数在带星号的参数的后边,那么后边的参数必须用关键字参数传参。
- 带**的不定长参数,输出是字典,用关键字参数
9.返回值
1.返回值的作用
返回值的作用就是将函数内部产生的数据,传递到函数的外部
初学者怎么确定函数需不需要返回值:看函数的功能有没有产生新的数据,如果有就将新的数据作为返回值返回。
2.确定函数返回值
在函数体中通过return关键字返回函数的返回值: return 数据
注意:
- 如果执行函数体的时候没有遇到return,函数的返回值是 None。
- return还具有提前结束函数的功能(执行函数体的时候,在哪里遇到return,函数就在那里结束。)
3.怎么在函数外部获取函数的返回值
获取函数调用表达式(调用函数的语句)的值就是获取函数的返回值,每一个函数调用语句其实都有一个结果,都是一个数据,这个结果就是这次调用的返回值。
作业:
-
编写一个函数,交换指定字典的key和value。
例如:dict1={'a':1, 'b':2, 'c':3} --> dict1={1:'a', 2:'b', 3:'c'} def change_dict(dict1): new_dict = {dict1[key]: key for key in dict1} return new_dict a = change_dict({'a': 4, 'b': 5}) print(a)
-
编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串
例如: 传入'12a&bc12d-+' --> 'abcd' def zi_mu(str1: str): new_str = '' for char in str1: if 'a' <= char <= 'z' or 'A' <= char <= 'Z': new_str += char return new_str str2 = zi_mu('12a&bc12d-+') print(str2)
-
写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母
例如: 'abc' -> 'Abc' '12asd' --> '12asd' def first(str3: str): for char in str3: if 'a' <= char <= 'z': new_str3 = str3.replace(char, chr(ord(char) - 32), 1) else: new_str3 = str3 return new_str3 str4 = first('aab12') print(str4)
-
写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束
例如: 字符串1:'abc231ab' 字符串2:'ab' 函数结果为: True 字符串1:'abc231ab' 字符串2:'ab1' 函数结果为: False def end_(m: str, n: str): len1 = len(n) new_m = '' for char in m[-len1::1]: new_m += char return new_m == n result = end_('abc231ab', 'ab') print(result)
-
写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串
例如: '1234921' 结果: True '23函数' 结果: False 'a2390' 结果: False def digit_(s: str): count = 0 len1 = len(s) for char in s: if '0' <= char <= '9': count += 1 return count == len1 result = digit_('d1234') print(result)
-
写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母
例如: 'abH23好rp1' 结果: 'ABH23好RP1' def upper_(s: str): new_s = '' for char in s: if not 'a' <= char <= 'z': new_s += char else: new_char = chr(ord(char) - 32) new_s += new_char return new_s new_str = upper_('sdf323') print(new_str)
-
写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充
例如: 原字符:'abc' 宽度: 7 字符:'^' 结果: '^^^^abc' 原字符:'你好吗' 宽度: 5 字符:'0' 结果: '00你好吗' def rjust_(s: str, c: str, l: int): ''' 创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充 :param s: 原始字符串 :param c: 填充字符 :param l: 填充后字符串长度 :return: 新字符串 ''' new_s = '' for char in range(l - len(s)): new_s += c new_s += s return new_s result = rjust_('abc', '^', 7) print(result)
-
写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1
例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0] 元素: 1 结果: 0,4,6 列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '赵云' 结果: 0,4 列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '关羽' 结果: -1 def index_(l: list, i): """ 统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1 :param l: 指定列表 :param i: 指定查找元素 :return: 指定元素的下标 """ list1 = [] for index, item in enumerate(l): if item == i: list1.append(index) else: if i not in l: list1.append(-1) return list1 result = index_(['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'], '关羽') print(result)
-
写一个自己的len函数,统计指定序列中元素的个数
例如: 序列:[1, 3, 5, 6] 结果: 4 序列:(1, 34, 'a', 45, 'bbb') 结果: 5 序列:'hello w' 结果: 7 def len_(s): """ 统计指定序列中元素的个数 :param s: 指定序列 :return: 序列中元素的个数 """ count = 0 for x in s: count += 1 return count result = len_((1, 34, 'a', 45, 'bbb')) print(result)
-
写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值
例如: 序列:[-7, -12, -1, -9] 结果: -1 序列:'abcdpzasdz' 结果: 'z' 序列:{'小明':90, '张三': 76, '路飞':30, '小花': 98} 结果: 98 def max_(s): if type(s) == dict: max_num = 0 for key in s: if s[key] > max_num: max_num = s[key] else: max_num = s[0] for x in s[1:]: if x > max_num: max_num = x return max_num result = max_({'小明':90, '张三': 76, '路飞':30, '小花': 98}) print(result)
-
写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在
例如: 序列: (12, 90, 'abc') 元素: '90' 结果: False 序列: [12, 90, 'abc'] 元素: 90 结果: True def in_(s, i): type_i = type(i) count = 0 for x in s: type_x = type(x) if type_x == type_i and i == x: count += 1 return count > 0 result = in_((12, 90, 'abc'), "90") print(result)
-
写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串
例如: 原字符串: 'how are you? and you?' 旧字符串: 'you' 新字符串:'me' 结果: 'how are me? and me?'