빠른 경험 함수는 독립적인 함수를 가진 코드 블록을 작은 모듈로 정리하고,
Encapsulate 독립 함수
encapsulation
함수의 역할 개발 중 언제 프로그래밍, 함수 사용은 작성 효율성과 코드 재사용
새
04_function
프로젝트 만들기04_函数
项目
复制之前完成的乘法表文件
修改文件,增加函数定义multiple_table():
新建另外一个文件,使用import
导入并且调用函数
定义函数的格式如下:
def 函数名():
def
是英文define
的缩写
函数名称应该能够表达函数封装代码的功能,方便后续的调用
函数名称的命名应该符合标识符的命名规则
可以由字母、下划线和数字组成
不能以数字开头
不能与关键字重名
调用函数很简单的,通过 函数名()
即可完成对函数的调用
需求
编写一个打招呼say_hello
的函数,封装三行打招呼的代码
在函数下方调用打招呼的代码
name = "小明" # 解释器知道这里定义了一个函数 def say_hello(): print("hello 1") print("hello 2") print("hello 3") print(name) # 只有在调用函数时,之前定义的函数才会被执行 # 函数执行完成之后,会重新回到之前的程序中,继续执行后续的代码 say_hello() print(name)
用 单步执行 F8 和 F7 观察以下代码的执行过程
定义好函数之后,只表示这个函数封装了一段代码而已
如果不主动调用函数,函数是不会主动执行的
能否将函数调用 放在 函数定义 的上方?
不能!
因为在使用函数名调用函数之前,必须要保证Python
已经知道函数的存在
否则控制台会提示NameError: name 'say_hello' is not defined
(名称错误:say_hello 这个名字没有被定义)
F8 Step Over可以单步执行代码,会把函数调用看作是一行代码直接执行
F7 Step Into可以单步执行代码,如果是函数,会进入函数内部
在开发中,如果希望给函数添加注释,应该在定义函数的下方,使用连续的三对引号
在连续的三对引号之间编写对函数的说明文字
在函数调用位置,使用快捷键CTRL + Q
이전에 완료된 내용 복사
파일을 수정하고 함수 정의를 추가하세요
🎜02. 기본 함수 사용법🎜multiple_table():
다른 파일을 만들고import
를 사용하여 함수를 가져오고 호출하세요2.1 함수 정의🎜
정의된 함수의 형식은 다음과 같습니다: 🎜
def sum_2_num(): num1 = 10 num2 = 20 result = num1 + num2 print("%d + %d = %d" % (num1, num2, result)) sum_2_num()로그인 후 복사로그인 후 복사🎜🎜
def는 영어<code>define
의 약어입니다. 🎜🎜🎜🎜🎜함수 이름🎜은 후속 호출을 용이하게 하기 위해 🎜함수 캡슐화 코드🎜의 기능을 표현할 수 있어야 합니다🎜🎜🎜🎜🎜이름 지정 함수 이름🎜은 🎜 🎜🎜식별자의 명명 규칙 🎜🎜🎜🎜🎜🎜을 준수해야 합니다. 🎜문자🎜, 🎜밑줄🎜 및 🎜숫자🎜🎜🎜로 구성되어야 합니다. 🎜🎜🎜숫자로 시작할 수 없습니다.🎜🎜🎜🎜🎜🎜키워드와 이름이 같을 수 없습니다.🎜🎜🎜🎜
2.2 함수 호출🎜
함수 호출은 매우 간단합니다.
함수 이름()
을 통해 함수 호출을 완료할 수 있습니다. 🎜2.3 첫 번째 기능 둘러보기🎜
🎜Requirements🎜🎜
🎜🎜안녕 인사하는 함수
say_hello
를 작성하고 세 줄의 인사 코드를 캡슐화합니다. 🎜🎜🎜🎜다음 코드를 호출합니다. 함수 아래에서 인사하세요 🎜🎜🎜def sum_2_num(num1, num2): result = num1 + num2 print("%d + %d = %d" % (num1, num2, result)) sum_2_num(50, 20)로그인 후 복사로그인 후 복사🎜를 사용하여 F8 및 F7🎜을 단계별로 진행하여 다음의 실행 프로세스를 관찰하세요. code🎜🎜🎜함수를 정의한 후에는 이 함수가 코드 조각을 캡슐화한다는 의미일 뿐입니다🎜🎜🎜🎜만약 함수를 적극적으로 호출하지 않으면 함수가 적극적으로 실행되지 않습니다🎜🎜🎜
생각 중
🎜🎜🎜함수 호출🎜을 🎜함수 정의🎜 위에 놓을 수 있나요? 🎜🎜🎜
🎜🎜할 수 없습니다! 🎜🎜🎜🎜함수를 호출하기 위해 🎜함수 이름을 사용🎜하기 전에
Python
이 이미 함수의 존재를 알고 있는지 확인해야 합니다🎜🎜🎜🎜 그렇지 않으면 콘솔에NameError 메시지가 표시됩니다. 이름 'say_hello'가 정의되지 않았습니다
(🎜이름 오류: 이름 say_hello가 정의되지 않았습니다🎜)🎜🎜🎜2.4 PyCharm 디버깅 도구🎜🎜🎜🎜F8 Step Over🎜는 한 번에 코드를 실행할 수 있으며, 함수 호출은 한 줄의 코드로 간주하여 직접 실행됩니다. 🎜🎜🎜🎜🎜F7 Step Into🎜can 코드를 단계별로 실행하면 함수인 경우 함수 내부로 들어갑니다🎜🎜🎜
2.5 함수 문서 주석🎜
🎜🎜개발 중에 함수에 주석을 추가하려면 🎜3개의 연속된 따옴표를 사용해야 합니다. 🎜🎜🎜🎜🎜under 🎜함수 정의🎜 함수에 대한 설명을 따옴표 사이에 적습니다. 🎜🎜🎜🎜🎜🎜함수 호출🎜 위치에서 단축키
CTRL + Q
를 사용하여 해당 내용을 확인하세요. 함수 설명🎜🎜🎜🎜🎜참고: 🎜 함수 본문은 상대적으로 독립적이고 🎜 🎜 함수 정의 위에 🎜는 다른 코드(주석 포함)와 함께 🎜 두 개의 빈 줄 🎜🎜을 유지해야 하기 때문입니다.
演练需求
开发一个sum_2_num
的函数
函数能够实现两个数字的求和功能
演练代码如下:
def sum_2_num(): num1 = 10 num2 = 20 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, 20)
函数,把具有独立功能的代码块组织为一个小模块,在需要的时候调用
函数的参数,增加函数的通用性,针对相同的数据处理逻辑,能够适应更多的数据
在函数内部,把参数当做变量使用,进行需要的数据处理
函数调用时,按照函数定义的参数顺序,把希望在函数内部处理的数据,通过参数传递
形参:定义函数时,小括号中的参数,是用来接收参数用的,在函数内部作为变量使用
实参:调用函数时,小括号中的参数,是用来把数据传递到函数内部用的
在程序开发中,有时候,会希望一个函数执行结束后,告诉调用者一个结果,以便调用者针对具体的结果做后续的处理
返回值是函数完成工作后,最后给调用者的一个结果
在函数中使用return
关键字可以返回结果
调用函数一方,可以使用变量来接收函数的返回结果
注意:
return
表示返回,后续的代码都不会被执行
def sum_2_num(num1, num2): """对两个数字的求和""" return num1 + num2 # 调用函数,并使用 result 变量接收计算结果 result = sum_2_num(10, 20) print("计算结果是 %d" % result)
一个函数里面又调用了另外一个函数,这就是函数嵌套调用
如果函数test2
中,调用了另外一个函数test1
那么执行到调用test1
函数时,会先把函数test1
中的任务都执行完
才会回到test2
中调用函数test1
的位置,继续执行后续的代码
def test1(): print("*" * 50) print("test 1") print("*" * 50) def test2(): print("-" * 50) print("test 2") test1() print("-" * 50) test2()
体会一下工作中 需求是多变 的
需求 1
定义一个print_line
函数能够打印*
组成的一条分隔线
def print_line(char): print("*" * 50)
需求 2
定义一个函数能够打印由任意字符组成的分隔线
def print_line(char): print(char * 50)
需求 3
定义一个函数能够打印任意重复次数的分隔线
def print_line(char, times): print(char * times)
需求 4
定义一个函数能够打印5 行的分隔线,分隔线要求符合需求 3
提示:工作中针对需求的变化,应该冷静思考,不要轻易修改之前已经完成的,能够正常执行的函数!
def print_line(char, times): print(char * times) def print_lines(char, times): row = 0 while row < 5: print_line(char, times) row += 1
模块是 Python 程序架构的一个核心概念
模块就好比是工具包,要想使用这个工具包中的工具,就需要导入 import这个模块
每一个以扩展名py
结尾的Python
源代码文件都是一个模块
在模块中定义的全局变量、函数都是模块能够提供给外界直接使用的工具
步骤
新建hm_10_分隔线模块.py
复制hm_09_打印多条分隔线.py
中的内容,最后一行 <strong>print</strong>
代码除外
增加一个字符串变量
name = "黑马程序员"
新建hm_10_体验模块.py
文件,并且编写以下代码:
import hm_10_分隔线模块 hm_10_分隔线模块.print_line("-", 80) print(hm_10_分隔线模块.name)
可以在一个 Python 文件中定义 变量 或者 函数
然后在另外一个文件中使用import
导入这个模块
导入之后,就可以使用模块名.变量
/模块名.函数
的方式,使用这个模块中定义的变量或者函数
模块可以让 曾经编写过的代码 方便的被 复用!
标示符可以由字母、下划线和数字组成
不能以数字开头
不能与关键字重名
注意:如果在给 Python 文件起名时,以数字开头 是无法在
PyCharm
中通过导入这个模块的
C
是compiled
编译过 的意思
操作步骤
浏览程序目录会发现一个__pycache__
的目录
目录下会有一个hm_10_分隔线模块.cpython-35.pyc
文件,cpython-35
表示Python
解释器的版本
这个pyc
文件是由 Python 解释器将模块的源码转换为字节码
Python
这样保存字节码是作为一种启动速度的优化
字节码
Python
在解释源程序时是分成两个步骤的
首先处理源代码,编译生成一个二进制字节码
再对字节码进行处理,才会生成 CPU 能够识别的机器码
모듈의 바이트코드 파일이 있으면 다음에 프로그램을 실행할 때 마지막으로 바이트코드를 저장한 이후 이후 소스 코드가 수정되지 않은 경우 Python은 .pyc 파일을 로드하고 이 단계를 건너뛰세요
Python
다시 컴파일하면 소스 파일과 바이트코드 파일의 타임스탬프를 자동으로 확인합니다.
소스 코드를 다시 수정하면 다음에 프로그램을 실행할 때 바이트코드가 자동으로 다시 생성됩니다. run
팁: 모듈 및 기타 모듈 가져오기 방법과 관련하여 후속 강좌가 점차 확대됩니다!
모듈은 Python 프로그램 아키텍처의 핵심 개념입니다
위 내용은 Python 함수의 기본 개념은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!