- 所谓函数,就是把具有独立功能的代码块,组织成为一个小模块,在需要的时候调用
- 函数的使用包含两个步骤:
- 1、定义函数–封装独立的功能
- 2、调用函数–享受封装的成果
- 函数的作用,在开发程序时,使用函数可以提高编写的效率以及代码的重用。
演练步骤:
1、新建函数
项目
2、复制之前完成的乘法表
3、修改文件,增加函数定义multiple_table():
4、新建另外一个文件,使用import导入并且调用函数
定义函数
def multiple_table():
# 在控制台连续输出一次递增的五行*。#
# 1、定义一个计数器变量,从1开始会比较方便。
row = 1
# 2、开始循环
while row <= 9:
# 增加一个小循环,专门负责当前行中,每一列的星星显示
col = 1
while col <= row:
he = col * row
print("%d * %d = %d" % (col,row,he),end="\t")
col += 1
#print("第 %d 行" % row)
# 这行代码的目的就是为了实现一行代码完成后实现换行
print("")
row += 1
快速体验
import 循环嵌套
循环嵌套.multiple_table()
函数的定义
- 格式
def 函数名():
函数的封装的代码
- def是英文define的缩写
- 函数名称应该能够表达函数封装代码的功能,方便后续的调用
- 函数名称的命名应该符合标识符命名规则
- 可以由字母、下划线和数字组成
- 不能以数字开头
- 不能与关键字重名
函数的调用
定义好函数之后,只表示这个函数封装了一段代码而已。
如果不主动调用函数,函数是不会主动执行的
调用函数只需要通过函数名就可以完成。
一个函数演练
- 1、编写一个打招呼say_hello的函数,封装打招呼的代码
- 在函数下方调用打招呼的代码
name = "Mr.王"
# 解释器知道这里定义了一个函数
def say_hello():
print('hello yali')
print('hello yangliu')
print('hello wangpeng')
print(name)
# 只有在调用函数时,之前定义的函数才会被执行
# 函数执行完成之后,会重新回到之前的程序中,继续执行后续的代码
say_hello()
print(name)
- python是解释性语言,所以在未定义函数之前是不能调用函数的。
函数的文档注释
- 在开发中,如果希望给函数添加注释,应该在定义函数的下方,使用连续的三对引号
- 在连续的三对引号之间快捷键
CTRL + Q
可以查看函数的说明信息
注意:因为函数体相对比较独立,函数定义的上方,应该和其他代码(包括注释)保留两个空行。
函数的参数
需求
- 开发一个
sum_2_num
的函数 - 函数能够实现两个数字的求和功能
def sum_2_num():
"""求和函数"""
num1 = 10
num2 = 15
result = num1 + num2
print("%d + %d = %d"%(num1,num2,result))
sum_2_num()
上述代码中存在一个问题,那就只能计算固定的两个值,那如何将参数传递给函数呢
函数参数的使用
- 在函数名后面的小括号内部填写参数
- 多个参数之间使用
,
分割
def sum_2_num(num1,num2):
"""求和函数"""
result = num1 + num2
print("%d + %d = %d"%(num1,num2,result))
sum_2_num(50,70)
形参和实参
- 形参:定义函数时,小括号中的参数,是用来接收参数用的,在函数内部作为变量使用
- 实参:调用函数时,小括号中的参数,是用来把数据传递到函数内部用的。
函数返回值
- 在程序开发中,有时候,会希望一个函数执行结束后,告诉调用者一个结果,以便调用者针对具体的结果做出后续的处理
- 返回值是函数完成工作后,最后给调用者的一个结果
- 在函数中使用
return
关键字可以返回结果 - 调用函数一方,可以使用便利来接受函数的返回结果
注意:
return
表示返回,后续的代码都不会被执行
def sum_2_num(num1, num2):
"""对两个数字的求和"""
result = num1 + num2
# 使用返回值,告诉调用函数一方计算的结果
return result
# 使用变量,来接收函数执行的返回结果
sum_result = sum_2_num(10, 20)
print("计算结果为 %d"%sum_result)
函数的嵌套调用
- 一个函数里面有调用了另外一个函数,这就是函数嵌套调用
- 如果函数
test2
中,又调用了另外一个函数test1
- 那么执行到调用
test1
函数时,会把函数test1
中的任务都执行完 - 才会回到
test2
中调用test1
的位置,继续执行后续的代码。
- 那么执行到调用
def test1():
print("wangpeng is yali" )
#test2()
def test2():
test1()
print("yali is wangpeng " )
test1()
定义一个函数能够打印任何字符组成的分割线
def print_line(char):
print(char * 50)
print_line("-")
定义一个函数能够打印任意重复次数的分割线
def print_line(char,time):
print(char * time)
print_line("-",50)
定义一个函数能够打印任何行数的分割线,要求符合上述需求。
def print_line(char, time):
"""
:param char: 分割线的字符串类型
:param time:单条分割线的字符串数量
:return:
"""
print(char * time)
def print_lines(times,char,time):
"""
:param times:分割线的行数
:param char: 分割线的字符串类型
:param time: 单条分割线的字符串数量
:return:
"""
row = 0
while row < times:
# 调用第一个函数
print_line(char, time)
row += 1
print_lines(5,"-",20)
使用模块中的函数
模块是python程序架构的一个核心概念
- 模块就好比是工具包,要想使用这个工具包中的工具,就需要导入import这个模块
- 每一个以扩展名
py
结尾的python
源代码文件都是一个模块 - 在模块中定义的全局变量、函数都是模块能够提供给外界直接使用的工具
第一个模块体验
- 新建
wp_10_分割线模块.py
文件并且编写以下代码:
def print_line(char, time):
"""
:param char: 分割线的字符串类型
:param time:单条分割线的字符串数量
:return:
"""
print(char * time)
def print_lines(times,char,time):
"""
:param times:分割线的行数
:param char: 分割线的字符串类型
:param time: 单条分割线的字符串数量
:return:
"""
row = 0
while row < times:
# 调用第一个函数
print_line(char, time)
row += 1
name = "wangpeng"
- 新建
wp_10_体验模块,.py
文件,代码如下
import wp_10_分割线模块
wp_10_分割线模块.print_line("-",50)
print(wp_10_分割线模块.name)
模块名也是一个标识符(文件名),所以要注意命名规则。
Pyc文件
c是compiled编译过的意思
操作步骤
- 1、浏览程序目录会发现一个
_pycache_
的目录 - 2、目录下会有一个
wp_10_分割线模块.cpython-37.pyc
文件,cpython-37
表示python解释器的版本 - 这个pyc文件是由python解释器将模块的源码转换为字节码
- python这样保存字节码是作为一种启动速度的优化