时间:2022-05-28 08:46:05 | 栏目:Python代码 | 点击:次
函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。
函数能提高应用的模块性,和代码的重复利用率。
你已经知道Python提供了许多内建函数(库函数),比如print()。
但你也可以自己创建函数,这被叫做用户自定义函数。
函数类型有:库函数、自定义函数。
(1).函数代码块以 def 关键词开头,后接函数标识符名称和圆括号()。
任何传入参数和自变量必须放在圆括号中间。圆括号之间可以用于定义参数。
(2).函数的第一行语句可以选择性地使用文档字符串—用于存放函数说明。
函数内容以冒号起始,并且缩进。
(3).return [表达式] 结束函数,选择性地返回一个值给调用方。不带表达式的return相当于返回 None。
注:如果没有返回值,那么return后面的表达式可不用写。
定义一个函数只给了函数一个名称,指定了函数里包含的参数(形式参数),和代码块结构。这个函数的基本结构完成以后,你可以通过另一个函数调用执行,也可以直接从Python提示符执行。调用函数时的参数,为实际参数。
函数的主要类型有:形式参数、实际参数,具体如上三中所述
1、必备参数
必备参数须以正确的顺序传入函数。调用时的数量必须和声明时的一样。调用printme()函数,你必须传入一个参数,不然会出现语法错误。
2、关键字参数(使用<键-值>来传参)
关键字参数和函数调用关系紧密,函数调用使用关键字参数来确定传入的参数值。
使用关键字参数允许函数调用时参数的顺序与声明时不一致,因为 Python 解释器能够用参数名匹配参数值。
3、默认参数
调用函数时,默认参数的值如果没有传入,则被认为是默认值。
4、不定长参数(可变长参数)
你可能需要一个函数能处理比当初声明时更多的参数。这些参数叫做不定长参数,和上述2种参数不同,声明时不会命名。
定义在函数内部的变量拥有一个局部作用域,定义在函数外的拥有全局作用域。
局部变量只能在其被声明的函数内部访问,而全局变量可以在整个程序范围内访问。调用函数时,所有在函数内声明的变量名称都将被加入到作用域中。如下实例:
例题(n的阶乘):
递推归纳:将问题转化为比原问题小的同类规模,归纳出一般递推公式,故所处理的对象要有规律的递增或递减。
递归终止:当规模小到小规模到一定程度应该结束递归调用,逐层返回常用语句条件来控制何时结束递归。
注:原问题层层分解为类似的子问题。
Python提供了文件对象,并内file_object =open(path,mode)。置了open函数来获取一个文件对象。Open函数的使用:其中,file_object是调用open函数后得到的文件对象;path是一个字符串,代表要打开文件的路径;而mode是打开文件的模式,常用的模式如下表所示。
在os.py中要打开Task1文件进行读写,需要使用r+模式,实现如下:f = open(’./Task1’,‘r+’)。简单一个语句便实现了打开文件的操作,之后对该文件的操作只需对新得到的文件对象f,使用文件对象提供的方法即可。
常用方法:
例题:
实例1将文件Task1的内容全部读入到fls列表中。实例二要将文件首字符为“3”的行中每一个数字加起来,不包括3,即“10 5 19 20 37”;然后,将结果写入到文件末尾。
分析:
首先要获取首字符3,为此,可以用格的listsplit()函数将每一行字符串按空格分解为每个元素不包含空。然后判断list[0]是不是字符3。然后需要计算该list从1号元素开始的所有元素的和。最后,需要将结果写回文件,所以,文件的打开方式应为“r+”。
#<程序:读取文件os.py,计算并写回> f = open("./Task1.txt",'r+'); fls = f.readlines() for line in fls: line = line.strip() lstr = line.split() if lstr[0] == '3': res = 0 for e in lstr[1:]: res+=int(e) f.write('\n4 '+str(res)); f.close()
#<程序:第三次培训作业1> def cf(x,n): if n==0: f=1; else: f=x*x**(n-1) return f x=int(input("请输入x值:")) n=int(input("请输入n值:")) f=cf(x,n) print("x的n次方的值为:",f)
#<第三次培训作业2> def age(n): if n==1: a=10 else: a=age(n-1)+2 return a print(age(5))