1. 函数基础
函数存在的价值:当一个功能需要反复使用的时候,如果没有函数,每次需要这个功能就必须把实现这个功能的代码写一遍。
实现功能对应的代码只需要写一遍(封装成函数),在每次需要这个功能的时候调用实现这个功能的函数。
- 什么是函数:
函数就是实现某一特定功能的代码的封装,将实现某一类功能的代码打包。 - 函数的分类
根据是由谁创建的,分为系统函数和自定义函数两种,
1)系统函数 - 由系统(python)创建的函数
2)自定义函数 - 由程序员自己创建的函数 - 函数的定义
语法:
def 函数名(形参列表):
函数说明文档
函数体
说明:
1)def – 关键字 固定写法
2)函数名 – 自定义 (所有字母都小写)
3)(): – 固定写法
4)形参列表 – 以‘变量名1,变量名2, 变量名3’的形式存在,变量的数量可以为0,每一个变量就是一个形参,形参的作用:将函数外部的数据传递到函数里面,
确定形参的方法:看实现函数的功能需不需要额外的数据,需要多少个额外的的数据。
5)函数说明文档 – 多行注释
“”"
(功能说明区)求一个数的阶乘:num
:param num: (参数说明)求阶乘的对象
:return:(返回值说明)
“”"
6)函数体 – 结构上,和def保持一个缩进的一条或多条语句,
逻辑上,函数体就是实现函数功能的代码。
案例:定义一个函数统计这个数的阶乘。
def sumN(num):
sum1 = 1
for i in range(1, num + 1):
sum1 += i
print(sum1)
sumN(100)
# 5050
案例:定义一个函数求两个数的乘积
def product(num1, num2):
print(num1 * num2)
product(10, 23)
# 230
练习1:定义一个函数统计字符串中数字字符的个数
def count_nums(str1):
"""
统计str1对应的字符串中数字字符的个数
:param str1:指定的字符串
:return: None
"""
count = 0
for i in str1:
if i.isdigit():
count += i
print(count)
count_nums('1234jj9')
# 5
练习2:定义一个函数,将两个字符串中所有的大写字母合并成一个新的字符串
def num(str1,str2):
sum=''
for i in str1+str2:
if i.isupper():
sum+=i
print(sum)
num('jH','SI')
# HSI
练习3:定义一个函数,删除列表中所有的空值(包括None,和其他空值(比如空字符串、空列表、空元组等))
def remove(list1):
for i in list1[:]:
# 怎么判断是否是空值,所有的0和空值都会转为false
if (not i) and (i != 0):
list1.remove(i)
print(list1)
remove([23, [], 24, 0])
# [23, 24, 0]
2. 调用函数
语法:
函数名(实参列表)
说明:
1)函数名 - 需要哪个函数对应的功能就调用哪个函数。已经定义过的函数的函数名。
2)实参列表:以‘数据1,数据2,数据3’的形式存在,这的每个数据就是一个实参。对应的数据可以是任何形式。变量名1,变量名2,变量名3=数据1,数据2,数据3形参=实参
重要结论:
定义函数不会执行函数体,调用函数的时候才会执行函数体
- 函数调用过程
每次在调用函数的时候,执行步骤:
第一步:回到函数定义的位置
第二步:传参(保证每个参数都有值),用形参和传参赋值,用300给z赋值
第三步:执行函数体
第四步:确定函数返回值。
第五步:回到函数调用的位置,接着往后执行。
def func1(x, y, z):
print(f'x:{x},y:{y},z:{z}')
func1(10, 23, 45)
# x:10,y:23,z:45
- 关于形参几种错误的写法
正确写法:
def count_num(str1):
count=0
for i in str1:
if i.isdigit():
count+=1
print(count)
count_num('sdfJo23')
# 2
错误写法1:
str1 = 'man闪烁234'
def count_nums2():
count = 0
for x in str1:
if x.isdigit():
count += 1
print(count)
count_nums2()
错误写法2:
def count_nums3():
str1 = 'man闪烁234'
count = 0
for x in str1:
if x.isdigit():
count += 1
print(count)
3. 函数参数
- 位置参数和关键字参数
根据实参的提高方式分为位置参数和关键字参数两种。可以一起用,必须保证位置参数在关键字参数前面。
1)位置参数:调用函数时,以‘实参1,实参2,实参3’的形式存在,让实参和形参从位置上一一对应
def func1(x, y, z):
print(f'x:{x},y:{y},z:{z}')
# 位置参数
func1(100, 200, 300)
# x:100,y:200,z:300
func1(200, 100, 300)
# x:200,y:100,z:300
2)关键字参数:以‘形参1=实参2,形参2=实参2,’通过=将实参和形参对应,
def func1(x, y, z):
print(f'x:{x},y:{y},z:{z}')
# 关键字参数
func1(x=100, y=200, z=300)
# x:100,y:200,z:300
- 参数默认值
在定义函数时,通过‘形参名=数据’的方式,给形参赋默认值,如果形参有默认值,
在调用函数时,有默认值的参数可以不用传参。
定义函数时,如果一个函数有的参数有默认值,有的参数没有默认值,没有默认值的形参必须在有默认值的形参的前面
def func2(x=10, y=20, z=30):
print(f'x:{x},y:{y},z:{z}')
func2()
# x:10,y:20,z:30
func2(100)
# x:100,y:20,z:30
func2(z=300)
# 如果想要跳过前面有默认值的参数,直接给后面的参数复制,使用关键字参数传参
# x:10,y:20,z:300
func2(x=10,y,z)
# 报错
- 参数类型说明
没有默认值参数的类型说明:直接在形参后面加’:类型名’。有默认值的参数,默认值数据对应的类型就是形参的类型。 - *对应的不定长参数
1)参数个数不确定
带 的不定长参数的本质是元组,接收到的所有实参是这个元组中的元素。如果在某一个形参前面加,这个形参会变成一个不定长参数,可以接受多个实参。
# 定义函数求多个数的和,不确定多少个数,可以使用不定长
```python
def stu(name, age, *awards):
print(name, age,*awards)
stu('小明', 18, '学生', '干部')
# 小明 18 ('学生', '干部')
# 定义函数求多个数的和,不确定多少个数,可以使用不定长
def sumN(*num):
sum = 0
for i in num:
sum += i
print(sum)
sumN(10, 23)
# 优化 求和至少给两个参数
def num1(num1,num2,*num):
sum=num1+num2
for i in num:
sum+=i
print(sum)
num1(5,6)
2)定义函数时单独使用*
yz必须用关键字传参,如果定义函数是,形参列表中有个独立的*,调用函数时,*后的关键字传参。
def func7(x, *, y, z):
print(x, y, z)
func7(10, y=23, z=34)
# 10,23,34
练习题
-
编写一个函数,交换指定字典的key和value。
例如:dict1={'a':1, 'b':2, 'c':3} --> dict1={1:'a', 2:'b', 3:'c'} def dict(dict1): dict2 = {} for key, value in dict1.items(): key, value = value, key dict2.setdefault(key, value) print(dict2) dict({'a': 1, 'b': 2, 'c': 3})
-
编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串
例如: 传入'12a&bc12d-+' --> 'abcd' def num(str1): str2 = '' for i in str1: if 'a' <= i <= 'z' or 'A' <= i <= 'Z': str2 += i print(str2) num('sjsddh2345')
-
写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母
例如: 'abc' -> 'Abc' '12asd' --> '12asd' def num(str1): str2 = '' if 'a' <= str1[0:] <= 'z': str2 += chr(ord(str1[0]) - 32) else: str2 += str1[0] print(str2 + str1[1:]) num('s1jsddh2345')
-
写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束
例如: 字符串1:'abc231ab' 字符串2:'ab' 函数结果为: True
字符串1:'abc231ab' 字符串2:'ab1' 函数结果为: False
def end_with(str1, str2):
new_str1 = ''
new_str2 = ''
for i in str1[-1:-len(str2) - 1:-1]:
new_str1 += i
for j in str2[-1::-1]:
new_str2 += j
print(new_str1 == new_str2)
end_with('abc231ab', 'ab1')
- 写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串
例如: '1234921' 结果: True
'23函数' 结果: False
'a2390' 结果: False
def num(str1):
for i in str1:
if not '0' <= i <= '9':
print(False)
break
else:
print(True)
num('234')
-
写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母
例如: 'abH23好rp1' 结果: 'ABH23好RP1' def num(str1): str2='' for i in str1: if 'a' <= i <= 'z': str2+=chr(ord(i)-32) else: str2+=i print(str2) num('abH23好rp1')
-
写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充
例如: 原字符:'abc' 宽度: 7 字符:'^' 结果: '^^^^abc' 原字符:'你好吗' 宽度: 5 字符:'0' 结果: '00你好吗' def num(str1): weight=5 for i in str1: if len(str1)<=weight: str1=f'{str1:0>5}' print(str1) break num('你好吗')
-
写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1
例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0] 元素: 1 结果: 0,4,6
列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '赵云' 结果: 0,4
列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '关羽' 结果: -1
def subscript(list1, element):
str1 = ''
for i, j in enumerate(list1):
if j == element:
str1 += str(f'{i},')
else:
if element not in list1:
str1 = '-1'
print(str1.strip(','))
subscript(['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'], '赵云')
- 写一个自己的len函数,统计指定序列中元素的个数
例如: 序列:[1, 3, 5, 6] 结果: 4
序列:(1, 34, 'a', 45, 'bbb') 结果: 5
序列:'hello w' 结果: 7
def num(list1):
count=0
for i in list1:
if i in list1:
count+=1
print(count)
num('hello w' )
- 写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值
例如: 序列:[-7, -12, -1, -9] 结果: -1
序列:'abcdpzasdz' 结果: 'z'
序列:{'小明':90, '张三': 76, '路飞':30, '小花': 98} 结果: 98
def max_value(xu_lie):
if type(xu_lie) == dict:
xu_lie = list(xu_lie.values())
max_num = xu_lie[0]
for i in xu_lie:
if max_num < i:
max_num = i
print(max_num)
max_value({'小明': 90, '张三': 76, '路飞': 30, '小花': 98})
- 写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在
例如: 序列: (12, 90, 'abc') 元素: '90' 结果: False
序列: [12, 90, 'abc'] 元素: 90 结果: True
def element_in(xu_lie, element):
for i in xu_lie:
if i == element:
print(True)
break
else:
print(False)
element_in((12, 90, 'abc'), 90)
- 写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串
例如: 原字符串: 'how are you? and you?' 旧字符串: 'you' 新字符串:'me' 结果: 'how are me? and me?'
def num(str1, str2, str3):
for i in range(len(str1)):
if str1[i:i + len(str2)] == str2:
str1 = str1[:i] + str3 + str1[i + len(str2):]
print(str1)
num('how are you? and you?', 'you', 'me')