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的函数的主要内容,如果未能解决你的问题,请参考以下文章

一文彻底搞懂 Python中的装饰器偏函数

一文彻底搞懂 Python中的装饰器偏函数

一文彻底搞懂python的垃圾回收机制及常量池验证

一文让你彻底搞懂 WebSocket 的原理

一文搞懂│mysql 的语法操作命令从入门到精通

一文搞懂│mysql 的语法操作命令从入门到精通