python与函数的故事(基础篇)

函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。

函数能提高应用的模块性,和代码的重复利用率。Python提供了许多内嵌函数,如下图:
这里写图片描述
可以通过查看官网了解pthon内置函数的功能:python官网之内置函数
也可以在交互命令行通过help(函数名)查看该函数帮助信息.

int("123")        #使用int函数可以将字符串"123" 转换成整型123

str(123)            #使用str函数可以将整型123转换成字符串"123"

abs(-9)            #使用abs函数可以给该整数取绝对值,得到的结果为整数9

当然也可以自己创建函数,这被叫做用户自定义函数。

def  print_HelloWorld ():                #编写函数头,创建了一个函数print_HelloWorld,函数名选取和变量名选取规则一致

        print("HelloWorld")                #编写函数体,输出该字符串

print_HelloWorld                               #调用该函数

以下自定义函数需要遵循的简单规则:

函数代码块以 def 关键词开头,后接函数标识符名称和圆括号()。

任何传入参数和自变量必须放在圆括号中间。圆括号之间可以用于定义参数。

函数的第一行语句可以选择性地使用文档字符串—用于存放函数说明。

函数内容以冒号起始,并且缩进。

return [表达式] 结束函数,选择性地返回一个值给调用方。不带表达式的return相当于返回 None。

形参和实参:
参数就是函数传递时的“变量”,也是函数的“输入值”,函数通过传递给它的参数实现调用过程或方法,当然有的函数是没有参数的,同理有的函数也不止一个参数

什么是“形参”呢?顾名思义,就是形式参数,也就是我们在定义函数的时候用的参数,这个参数只具有形式上的意义,并不会有特定含义;那么“实参”呢?举一反三的小伙伴可能也猜出来了,那就是实际参数,实际参数是我们调用函数的时候按照形参的要求赋予(或者叫传递)给函数的输入。

def  函数名(形参1,形参2....):

        函数体

函数名(实参1,实参2...)

我们来看个例子

def  parameter(a,b):            #定义一个函数parameter,传入形参a,b,这两个形参只是占位置,也可以理解为用来接受实参的值

        print(a)                        #a=5

        print(b)                        #b=10

parameter(5,10)                    #调用所定义的函数,并传入实参5和10,将其分别赋予形参的a和b,此时a=5,b=10

例子中,a和b就是形式参数,简称形参,而在调用函数时输入的5和10就是实际参数,简称实参

对于形参和实参的理解,我们可以使用下面的思维定式去理解(仅限理解层面是正确的),那就是:

形参就是在定义函数的时候占位置用的,而实际的参数才是幕后需要参与函数的人

函数的返回值
“返回值”介绍:

现实生活中:

我给儿子10块钱,让他给我买包烟。这个例子中,10块钱是我给儿子的,就相当于调用函数时传递到参数,让儿子买烟这个事情最终的目标是,让他把烟给你带回来然后给你对么,,,此时烟就是返回值

开发中的场景:

定义了一个函数,完成了获取室内温度,想一想是不是应该把这个结果给调用者,只有调用者拥有了这个返回值,才能够根据当前的温度做适当的调整

综上所述:

所谓的”返回值”就是在函数完成一件事情后,最后给调用者的结果,每一个函数都有返回值,如果不提供返回值,函数默认返回None.

举例说明:

def add2num(a,b):            #定义一个函数,传入形参a,b占位,用来接收实参的值

        c=a+b                         #该函数用来计算两个数的和

add2num(1,2)                        #调用该函数,并传入实参1和2,那么a=1,b=2

print(add2num(1,2))                #打印调用该函数之后的结果,为None

为什么会获得None这个值呢?

因为每个函数都有返回值,如果没有return 返回值的话,默认为None,这个程序执行流程如下:从上往下执行,看到定义函数时先不执行,先执行调用函数,然后把实参传给该函数,然后从上往下执行,执行结束后python程序将该函数释放,发现没有return 返回值,那么把None值传给该函数,那么输出该函数的话,获得的值便是None

带入返回值测试(注意:运行函数体时,一旦运行了return之后,函数便编译结束,并把return后面的值赋值给调用函数的那个值))

def add2num(a,b):            #定义一个函数,传入形参a,b占位,用来接收实参的值        

            c=a+b                         #该函数用来计算两个数的和    

            return c                        #返回该函数的值为c

add2num(1,2)                        #调用该函数,并传入实参1和2,那么a=1,b=2

print(add2num(1,2))                #打印调用该函数之后的结果,为3,即获取的是函数的返回值

函数中执行多个return

第一种方法:使用列表,字典,元组等存储多个数据

def test():

        a=11

        b=22

        c=33

        d=[a,b,c]                    #使用列表存储三个变量

        return d                        #返回列表d的值

num=test()                        #调用该程序的值即为程序返回值,在这个程序中返回值为变量d,即将变量d赋值给变量num

print(num)                        #程序输出值为[11,22,33]

第二种方法:将变量打包做成整体然后返回

def tets():

        a=11

        b=22

        c=33

        return [a,b,c]            #将三个变量打包成一个列表然后返回,也可以打包成字典,元组,字符等等,返回值为任意一个值,

        #return  a,b,c        #这种返回值也可以使用,相当于return (a,b,c),那么返回值为元组(11,22,33)

num=tets()

print(num)                #程序输出值为:[11,22,33]

猜你喜欢

转载自blog.csdn.net/qq_39353923/article/details/82149349
今日推荐