【python入门到精通】一文让你彻底搞懂python的函数

简介: 【python入门到精通】一文让你彻底搞懂python的函数

🚀 作者 :“大数据小禅”


🚀 粉丝福利 :加入小禅的大数据社群


🚀 欢迎小伙伴们 点赞👍、收藏⭐、留言💬


目录

Python中的函数及其调用

对于函数的理解:

python中的自定义函数

自定义空函数

Python特性之让函数返回多个值

核心注意点:

实战部分: 函数核心知识之函数的递归算法

最终结束条件,比如下面的if n==1。

实例部分,使用递归,做阶乘运算 4! 4*3 *2 *1=24

Python中的函数及其调用

对于函数的理解:


函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。
函数能提高应用的模块性,和代码的重复利用率。
比如我们在计算图形面积的时候,我们知道计算圆面积的公式是  πr²
这个时候,我们就能将这样一个功能抽象成一个函数
对于函数的调用,相比大家也不陌生。我们之前接触过的print()、hex()这些都是函数
函数的调用非常简单,只要函数名(参数)
这里要注意一点:参数一定要符合函数定义时的入参,对于Python中提供的函数,可以使用help(函数
名)来查看相关调用时的相关说明,如   help(hex)查看函数相应的一些说明
在Python中,万物皆对象,也就意味着函数名也是指向一个函数对象的引用,我们可以把函数名赋给一
个变量,相当于给这个函数起了一个“别名。如下:
def run():
  pass 
  return (返回的一个数值,可以使列表,数字)
run()

image.png

### 定义函数的基本结构
#### def 函数名(入参):
#### 函数逻辑
#### return

image.png

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

image.png

def empty_fun():
pass
print(empty_fun())

image.png

def my_fun():
 return [1, 2, 3]
print(my_fun())
>>>[1,2,3]

image.png

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

image.png

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

image.png

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

image.png

'''斐波那契数列(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*)'''

image.png

import sys
print(sys.getrecursionlimit())   拿他最大的一个递归深度
输出结果:1000

image.png

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

image.png

相关文章
|
27天前
|
大数据 数据处理 数据安全/隐私保护
Python3 迭代器与生成器详解:从入门到实践
简介:本文深入解析Python中处理数据序列的利器——迭代器与生成器。通过通俗语言与实战案例,讲解其核心原理、自定义实现及大数据处理中的高效应用。
67 0
|
8天前
|
测试技术 开发者 Python
Python单元测试入门:3个核心断言方法,帮你快速定位代码bug
本文介绍Python单元测试基础,详解`unittest`框架中的三大核心断言方法:`assertEqual`验证值相等,`assertTrue`和`assertFalse`判断条件真假。通过实例演示其用法,帮助开发者自动化检测代码逻辑,提升测试效率与可靠性。
77 1
|
9天前
|
缓存 测试技术 Python
Python装饰器:优雅地增强函数功能
Python装饰器:优雅地增强函数功能
159 99
|
9天前
|
存储 缓存 测试技术
Python装饰器:优雅地增强函数功能
Python装饰器:优雅地增强函数功能
143 98
|
13天前
|
缓存 Python
Python中的装饰器:优雅地增强函数功能
Python中的装饰器:优雅地增强函数功能
|
13天前
|
调度 数据库 Python
Python异步编程入门:asyncio让并发变得更简单
Python异步编程入门:asyncio让并发变得更简单
82 5
|
2月前
|
Python
Python 函数定义
Python 函数定义
101 1
|
21天前
|
算法 安全 数据安全/隐私保护
Python随机数函数全解析:5个核心工具的实战指南
Python的random模块不仅包含基础的随机数生成函数,还提供了如randint()、choice()、shuffle()和sample()等实用工具,适用于游戏开发、密码学、统计模拟等多个领域。本文深入解析这些函数的用法、底层原理及最佳实践,帮助开发者高效利用随机数,提升代码质量与安全性。
110 0
|
26天前
|
数据采集 存储 XML
Python爬虫入门(1)
在互联网时代,数据成为宝贵资源,Python凭借简洁语法和丰富库支持,成为编写网络爬虫的首选。本文介绍Python爬虫基础,涵盖请求发送、内容解析、数据存储等核心环节,并提供环境配置及实战示例,助你快速入门并掌握数据抓取技巧。
|
29天前
|
存储 缓存 安全
Python字典:从入门到精通的实用指南
Python字典如瑞士军刀般强大,以键值对实现高效数据存储与查找,广泛应用于配置管理、缓存、统计等场景。本文详解字典基础、进阶技巧、实战应用与常见陷阱,助你掌握这一核心数据结构,写出更高效、优雅的Python代码。
42 0

推荐镜像

更多