所谓函数,就是把具有独立功能的代码块组织成为一个小模块,在需要的时候调用
函数的使用包含两个步骤
1.定义函数-C封装独立的功能
2.调用函数-C享受封装的成果
函数的作用:在开发时,使用函数可以提高编写的效率以及代码的重用‘'
函数:
函数是带名字的代码块,用于完成具体的工作需要在程序中多次执行同一项任务时,你无需反复编写完成该任务的代码,而只需调用该任务的函数,让python运行其中的代码,你将发现,通过使用函数,程序编写,阅读,测试 和 修复都将更容易
1.定义函数
def 函数名():
函数封装的代码
1.def是英文define的缩写
2.函数名称应该能够表达函数封装代码的功能,方便后续的调用
3.函数名称的命名应该符合标识符的命名规则
可由字母,下划线和数字组成
不能以数字开头
不能与关键字重名
参数的作用
函数,把具有独立功能的代码块组织成为一个小模块,在需要的时候调用
函数的参数,增加函数的通用性,针对相同的数据处理逻辑,能够适应更多的数据
1.在函数内部,把参数当作变量使用,进行需要的数据处理
2.函数调用时,按照函数定义的参数顺序,把希望在函数内部处理的数据,通过
参数传递
形参和实参
形参:定义函数时,小括号中的参数,是用来接收参数用的,在函数内部作为变量使用
实参:调用函数时,小括号中的参数,是用来把数据传递到函数内部用的
函数的返回值
在程序开发中,有时候,会希望一个函数执行结束后(举例子:温度计函数,要返回给我>们当前的温度),告诉调用者一个结果,以便调用者针对具体的结果作出后续的处理
返回值是函数完成工作后,最后给调用者的一个结果
在函数中使用return关键字可以返回结果
调用函数一方,可以使用变量来接收函数的返回结果
局部变量和全局变量
局部变量是在函数内部定义的变量,只能在函数内部使用
全局变量是在函数外部定义的变量,(没有定义在某一个函数内),所有函数内部都可以使
用这个变量
局部变量
局部变量是在函数内部定义的变量,只能在函数内部使用
函数执行结束后,函数内部的局部变量,会被系统回收
不同的函数,可以定义相同的名字的局部变量,但是各用各的不会产生影响
局部变量的作用
在函数内部使用,临时保存函数内部需要使用的数据
变量进阶
目标
变量的引用
可变和不可变类型
局部变量和全局变量
变量的引用
变量和数据都是保存在内存中的
在python中函数的参数传递以及返回值都是靠引用传递的
引用的概念
在python中
变量和数据是分开存储的
数据保存在内存中的一个位置
变量中保存的是数据在内存中的地址
变量中记录数据的地址,就叫做引用
使用id()函数可以查看变量中保存数据所在内存的地址
模块文件:每一个python源文件都可以是一个模块文件,可以在一个python文件中定义函数或者变量,然后在另一个函数使用import filename导入这个模块,导入之后,可以使用模块名.变量或者模块名.函数的方式使用这个模块文件的函数和变量
首先定义一个函数
# 1.定义一个函数,能够打印*组成的一条分隔线 def print_line(): print '*' * 50 print_line() # 2.定义一个函数能够打印由任意字符串组成的分割线 def print_line(char): print char * 50 print_line('&') # 3.定义一个函数能够打印任意重复次数的分隔线 def print_line(char,times): print char * times print_line('%',20) # 4.定义一个函数能够打印五行分隔线, # 分隔线要求符合需求3 # def print_line(char,times): # print char * times def print_lines(char,times): """打印多行分隔线 :param char: 分隔线使用的分隔字符 :param times: 分隔线重复的次数 """ row = 0 while row < 5: print_line(char,times) row += 1 print_lines('!',70)
模块文件:每一个python源文件都可以是一个模块文件
可以在一个python文件中定义函数或者变量
然后在另一个文件中使用 import filename 导入这个模块
导入之后,就可以使用 模块名.变量/模块名.函数的方式,
使用这个模块中定义的函数和变量
import func_04 import fun_01 print func_04.name func_04.print_lines('*',80) result = fun_01.sum_2_sum(3,6) print result
2.模块的调用
test1文件中 title = '模块1' # 函数 def demo1(): print '今天学习%s' %title # 类 class Cat(object): pass title = '模块2' test2文件中 # 函数 def demo1(): print '今天学习%s' %title # 类 class Dog(object): pass
import test1 import test2 test1.demo1() test2.demo1() cat = test1.Cat() print cat dog = test2.Dog() print dog
使用as指定模块的别名(大驼峰命名法)
from test1 import Cat # 如果重名的话,则第二个导入的覆盖同名的第一个 from test1 import demo1 as test_demo1 from test2 import demo1 cat = Cat() print cat test_demo1() demo1()
2.python的解释器在导入模块的时候,会:
1.搜索当前目录指定的模块文件,如果有就直接导入
2.如果没有,再搜索系统目录
注意:在开发时,给文件起名,不要和系统模块文件重名
所以在导入文件时,不能起和系统文件重名的名字,例如下例的random
import random ran = random.randint(1,10) print ran
3.name属性
功能:测试模块的的代码只在测试情况下被运行,而在导入时不会被运行
name时python的一个内置属性,记录这一个字符串
被其他文件导入时,name就是模块名
如果是当前执行的程序name就是main
def wn(): print '今天是个好日子' if __name__ == '__main__': print __name__ print '模块的引用'
调用函数 import test wn = test.wn() print wn
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理