python入门到精通一文让你彻底搞懂python的函数
Posted 大数据小禅
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python入门到精通一文让你彻底搞懂python的函数相关的知识,希望对你有一定的参考价值。
🚀 作者 :“大数据小禅”
🚀 粉丝福利 :加入小禅的大数据社群
🚀 欢迎小伙伴们 点赞👍、收藏⭐、留言💬
目录
Python中的函数及其调用
对于函数的理解:
函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。
函数能提高应用的模块性,和代码的重复利用率。
比如我们在计算图形面积的时候,我们知道计算圆面积的公式是 πr²
这个时候,我们就能将这样一个功能抽象成一个函数
对于函数的调用,相比大家也不陌生。我们之前接触过的print()、hex()这些都是函数
函数的调用非常简单,只要函数名(参数)
这里要注意一点:参数一定要符合函数定义时的入参,对于Python中提供的函数,可以使用help(函数
名)来查看相关调用时的相关说明,如 help(hex)查看函数相应的一些说明
在Python中,万物皆对象,也就意味着函数名也是指向一个函数对象的引用,我们可以把函数名赋给一
个变量,相当于给这个函数起了一个“别名。如下:
def run():
pass
return (返回的一个数值,可以使列表,数字)
run()
python中的自定义函数
介绍怎么定义属于自己的函数
### 定义函数的基本结构
#### def 函数名(入参):
#### 函数逻辑
#### return
实例如下:
PI = 3.14
def circle_area(r):
return PI * r **2
print(circle_area(2))
>>>12.56
a=4
def rum(r):
return a+r
print(rum(2))
>>>6
自定义空函数
def empty_fun():
pass
print(empty_fun())
Python特性之让函数返回多个值
简介:介绍如何让函数返回多个值
直接在函数里把多个返回值按一定顺序放到list、tuple里,实例如下:
def my_fun():
return [1, 2, 3]
print(my_fun())
>>>[1,2,3]
多个返回值以key-value的形式放在字典(dict)里
def my_fun():
return "x": 1, "y": 2, "z": 3
print(my_fun())
>>>"x": 1, "y": 2, "z": 3
def my_fun():
return "x": 1, "y": 2, "z": 3
my_fun()
>>>这样调用返回空值
def my_fun():
return 4
print(my_fun()+2)
>>>6
在return 的时候直接返回多个逗号分隔的值,在返回的时候,也可以直接用多个变量接收:
def my_fun():
return val1, val2, val3
x, y, z = my_fun()
#接收多个返回值
def my_fun():
return 1,2,3
x, y, z = my_fun()
print(x)
print(y)
print(y)
>>>
1
2
3`在这里插入代码片`
def my_fun():
return 1,2,3
a=my_fun()
i=len(a) #3
for j in range(i):
print(a[j])
>>>
1
2
3
核心注意点:
返回多个参数时,如果想一次性用多个变量接收,那么有多少个返回值就得有多少个变量接收。
其实返回多个值 ,本质上返回的是一个元组:
def my_fun():
return 1, 2, 3
print((my_fun()))
print(type(my_fun()))
>>>(1,2,3)
>>> <class 'tuple'>
实战部分: 函数核心知识之函数的递归算法
一句话说明什么是递归?
要了解什么是递归,得先了解什么是递归
啥?不理解?没关系,那给你讲个故事吧
#从前有座山,山里有座庙,庙里有个和尚,和尚在讲故事,故事讲的是–从前有座山,山里有座
庙,庙里有个和尚,和尚在讲故事,故事讲的是–从前有座山…
递归说到底,就是自己调用自己特别注意的点:当自己写递归函数时,首要步骤是要先写函数的
最终结束条件,比如下面的if n==1。
实例部分,使用递归,做阶乘运算 4! 4*3 *2 *1=24
递归的方式,n*f(3) n*f(3)*f(2)....
def factorial(n):
if n == 1:
return 1
else:
return n * factorial(n-1)
print(factorial(4))
>>>24
使用递归实现求斐波那契数列第n项的值
'''斐波那契数列(Fibonacci sequence),指的是这样一个数列:1、1、2、3、5、8、13、21、
34、……在数学上,斐波纳契数列以如下被以递推的方法定义:F(1)=1,F(2)=1, F(n)=F(n-1)+F(n2)(n>=3,n∈N*)'''
python中有最大的递归层级,可使用如下代码获取最大层级:
import sys
print(sys.getrecursionlimit()) 拿他最大的一个递归深度
输出结果:1000
使用递归实现求斐波那契数列第n项的值:
def feb(n):
if n <= 2:
return 1
else:
return feb(n - 1) + feb(n - 2)
print(feb(5))
>>>
5
推导过程:
f5 | f4+f3 |f3+f2+f2+f1|f2+f1+f2+f2+f1
本章的python函数教程到此为止,希望对你有所帮助。
以上是关于python入门到精通一文让你彻底搞懂python的函数的主要内容,如果未能解决你的问题,请参考以下文章