本次讲解函数,由于内容比较多,小编列了个大纲,主要有一下内容:

1. 函数基本语法及特性

2. 函数参数

3.局部变量

4. 返回值

5.嵌套函数

6.递归

7.匿名函数

8.高阶函数

9.内置函数

1. 函数基本语法及特性

函数的定义:函数是指将一组语句的集合通过一个名字(函数名)封装起来,要想执行这个函数,只需调用其函数名即可

函数的特性:

  1. 减少重复代码
  2. 使程序变的可扩展
  3. 使程序变的易维护

函数的语法定义

直接上代码:

  1. # def 是定义函数的关键字
  2.  
  3. def test():#test既是函数名
  4. print('学习Python的第一个函数')
  5.  
  6. test() #调用函数

同时函数也可以带参数

  1. a, b = 1, 3
  2.  
  3. # 带参函数
  4. def test(x, y): # x 和 y 即是在我们调用函数时传入的参数
  5. return x + y # 返回执行的结果
  6.  
  7. c = test(a, b) # 把函数返回结果赋值给 C
  8. print(c)
2. 函数参数

在说函数参数前,大家需要了解一个知识点,形参 & 实参

何为形参?

既变量只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的内存单元。

因此,形参只在函数内部有效,函数调用结束返回主调用函数后则不能再使用该形参变量

何为实参?

既可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,以便把这些值传送给形参。

因此应预先用赋值,输入等办法使参数获得确定值

这么说可能有些不理解,还是来个实例让大家更加清晰:

  1. a, b = 1, 3
  2.  
  3. def test(x, y): # x 和 y 即是形参
  4. return x + y
  5.  
  6. c = test(a, b) # a,b既是实参
  7. print(c)

关键参数

上面的例子中,我们调用函数传参是根据函数的形参位置来传递的。

既 a 传给 x ,b 传给 y。这种叫做位置参数。

我们还可以使用关键参数,既传递的时候给函数的参数名传递你的值:

  1. a, b = 1, 3
  2.  
  3. # 带参函数
  4. def test(x, y):
  5. return x + y
  6.  
  7. c = test(y=a, x=b)#这里把 a 传给 y b 传给 x
  8. print(c)

这样参数就可以不用按照顺序传递,根据参数名传递给函数。

我们甚至可以把位置参数和关键参数同时使用:

  1. a, b = 1, 3
  2.  
  3. def test(x, y):
  4. return x + y
  5.  
  6. c = test(1, y=b)
  7. print(c)

如果同时使用一定要注意:关键参数必须要放在位置参数的后面,并且已经传值的位置参数不能再用关键参数

下面是一些错误的用法:

  1. c = test(x=a, b)
  2. #报错:TypeError: test() got multiple values for argument 'x'
  3. c = test(a, x=b)
  4. #报错:TypeError: test() got multiple values for argument 'x'

默认参数

参数还可以设置一个默认值,这样我们在调用的时候既可以不传参给默认参数

  1. def test(x, y, z=9): # 设置了 z 的默认值是 9
  2. print(x + y + z)
  3.  
  4. test(1, 3)#如果我们第三个参数也就是z 不传的话,z的默认值就是9
  5. test(1, 3, 10)#我们传了第三个参数,则 z 的值就变成10

非固定参数

所谓非固定参数就是可以传递任意个数的参数,比如你的函数在定义的时候不能确定用户想传入多少个参数,就可以使用

  1. def test(*args): # 使用 *args, 这里args可以改成任意变量名,但是不建议这么做。
  2. print(args)
  3.  
  4. test()
  5. # 输出结果:()
  6. test(1, 2)
  7. # 输出结果:(1, 2)
  8. test(1, 2, '承受', 'Python')
  9. # 输出结果:(1, 2, '承受', 'Python')

调用函数可以传入任意个数的参数,然后转换成 元组 的形式

3.局部变量

局部变量:就是只能在局部使用的变量

  1. name = 'Cheng Shou'
  2.  
  3. def change_name(name):
  4. print('改变前:', name)
  5. name = '承受'
  6. print('改变后:', name)
  7.  
  8. change_name(name)
  9.  
  10. print('在外面在看下name的值:', name)
  11.  
  12. #输出结果:
  13. #改变前: Cheng Shou
  14. #改变后: 承受
  15. #在外面在看下name的值: Cheng Shou

从上面的例子大家发现了没?函数里面的name修改了,函数外面的name没有改变。

其实函数里面的name 就是局部变量,他并没有调用外部的name。

那函数里面就不能使用全局变量了吗?非要用也是可以的

  1. name = 'Cheng Shou'
  2.  
  3. def change_name():
  4. global name #在函数中使用global既可
  5. print('改变前:', name)
  6. name = '承受'
  7. print('改变后:', name)
  8.  
  9. change_name()
  10.  
  11. print('在外面在看下name的值:', name)
  12.  
  13. #输出结果:
  14. #改变前: Cheng Shou
  15. #改变后: 承受
  16. #在外面在看下name的值: 承受

使用global 既可,我们的全局变量也被修改了。

当然不建议这么做。

全局变量与局部变量

在子程序中定义的变量称为局部变量,在程序的一开始定义的变量称为全局变量。
全局变量作用域是整个程序,局部变量作用域是定义该变量的子程序。
当全局变量与局部变量同名时:
在定义局部变量的子程序内,局部变量起作用;在其它地方全局变量起作用
4. 返回值

其实我们第一个例子中就有用到返回值,既 return 语句。return可以吧函数的执行结果返回

返回值记住两点:

1.函数在执行过程中只要遇到 return 语句就会停止函数的执行,并且返回结果。所以 return 语句出现就代表着函数结束

2.如果函数中未使用 return ,那函数执行完毕后,返回的值为 None

5.嵌套函数

顾名思义就是函数里面套函数,小编看到这个也是内心惊呼一声:python 果然牛掰

那么怎么套呢,上代码:

  1. name = 'Cheng Shou'
  2.  
  3. def change_name():
  4. name = '小承'
  5.  
  6. def change_name2():
  7. name = '小受'
  8. print('第三层:', name)
  9.  
  10. change_name2() # 调用内存函数
  11. print('第二层:', name)
  12.  
  13. change_name()
  14. print('最外层:', name)
  15.  
  16. #输出结果:
  17. #第三层: 小受
  18. #第二层: 小承
  19. #最外层: Cheng Shou

神奇吧,一层套一层,跟俄罗斯套娃一样

至于这个嵌套函数什么作用,之后学习到装饰器的时候我们就知道了。

6.递归

在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。

说白了,就是在函数里面调用自身函数

  1. def subtraction(n):
  2. print(n)
  3. if n < 1:
  4. return n
  5. return subtraction(n-1)
  6.  
  7. subtraction(5)
  8.  
  9. #输出结果:
  10. #
  11. #
  12. #
  13. #
  14. #
  15. #

注意:python默认的递归深度是很有限的(默认是1000),因此当递归深度超过999的样子,就会引发这样的一个异常。

报错:RecursionError: maximum recursion depth exceeded while calling a Python object

如果你的业务需要递归深度超过1000,则需要修改递归深度的值

  1. import sys
  2. sys.setrecursionlimit(10000)

导入sys模块,然后设置,需要多大就设置多大既可。

一般我们的业务代码不建议超过默认深度,否则代码性能不好。

在二分查找的时候,我们会用到递归,不过这讲到算法问题本篇就直接带过,后续有时间小编在写一篇算法相关的文章

递归特性:

1. 必须有一个明确的结束条件

2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少

3. 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出)

7.匿名函数

匿名函数就是不需要显式的指定函数

  1. def test(n):
  2. return n + 1
  3.  
  4. print(test(2))
  5. # 上面的函数修改成匿名函数后
  6. test = lambda n: n + 1
  7. print(test(2))

一般匿名函数是和其它函数搭配使用的,如下

  1. print(map(lambda x: x ** 2, [1, 2, 3, 4, 5]) )
  2. #输出:[1, 4, 9, 16, 25]
8.高阶函数

变量可以指向函数,函数的参数能接收变量,那么一个函数就可以接收另一个函数作为参数,这种函数就称之为高阶函数。

简单的说就是把函数当做参数传递给另一个函数,在函数中调用传递过来的函数。

  1. def add(x, y, func):
  2. return func(x) + func(y)
  3.  
  4. def square(n):
  5. return n ** 2
  6.  
  7. res = add(3, 6, square)
  8. print(res)

这里把square函数,传递给了add ,并且在add中使用了 square函数。这便实现了高阶函数

9.内置函数

直接展示一张图,不做详解,大家使用到的时候在了解既可。

Python学习,第八课 - 函数的更多相关文章

  1. Python学习第八课——函数

    python函数(def) def test(x): # x为形参 y = x + 20 return y # def:定义函数的关键字 # test:函数名 # ():内定义参数 # x+=1:代码 ...

  2. python学习第八讲,python中的数据类型,列表,元祖,字典,之字典使用与介绍

    目录 python学习第八讲,python中的数据类型,列表,元祖,字典,之字典使用与介绍.md 一丶字典 1.字典的定义 2.字典的使用. 3.字典的常用方法. python学习第八讲,python ...

  3. Python学习第六课

    Python学习第六课 课前回顾 列表 创建 通过 [] :写在[]里,元素之间用逗号隔开 对应操作: 查 增 append insert 改(重新赋值) 删除(remove del pop(删除后会 ...

  4. Python学习第七课

    Python学习第七课 'Alex' "Alex"print('hello'*5) #重复输出字符串 print('hellowold'[2:]) #类似于切片操作:会取出 llo ...

  5. Elasticsearch7.X 入门学习第八课笔记-----索引模板和动态模板

    原文:Elasticsearch7.X 入门学习第八课笔记-----索引模板和动态模板 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接: ...

  6. Python学习笔记之常用函数及说明

    Python学习笔记之常用函数及说明 俗话说"好记性不如烂笔头",老祖宗们几千年总结出来的东西还是有些道理的,所以,常用的东西也要记下来,不记不知道,一记吓一跳,乖乖,函数咋这么多 ...

  7. python学习交流 - 内置函数使用方法和应用举例

    内置函数 python提供了68个内置函数,在使用过程中用户不再需要定义函数来实现内置函数支持的功能.更重要的是内置函数的算法是经过python作者优化的,并且部分是使用c语言实现,通常来说使用内置函 ...

  8. Python学习笔记八

    类的高级用法 多态:   在其他语言,使用的是类的继承. 在python中,不需要指定数据类型. 基于TCP协议的socket通信实现: 类似于打电话的情景. 服务端: 1.买手机 2.插卡 3.开机 ...

  9. Python学习笔记010——匿名函数lambda

    1 语法 my_lambda = lambda arg1, arg2 : arg1 + arg2 + 1 arg1.arg2:参数 arg1 + arg2 + 1 :表达式 2 描述 匿名函数不需要r ...

  10. Python学习之路6☞函数,递归,内置函数

    一python中的函数 函数是逻辑结构化和过程化的一种编程方法. python中函数定义方法: def test(x): "The function definitions" x+ ...

随机推荐

  1. Visio常规图表

    包含的就是一些形状模块 比如框图就包含了“方块”以及“具有凸起效果的块”两个形状模版 打开visio 新建的时候选择常规类别 具有透视效果的框图 下面是基本操作: 这是自动调整大小的框 不能调整大小 ...

  2. 基于jquery的带事件显示功能的日历板插件calendar.js

    项目中需要用到一个日历板控件,要求能显示事件,于是想到了一年前在app项目上写的一个粗略版日历板,然后又想着这个可能以后还会用 于是我就封装了一下,能满足基本要求,如果有需要更多功能的也可以自行修改源 ...

  3. Flask框架知识点整合

    Flask 0.Flask简介 Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收ht ...

  4. ELK部署检测nginx日志demo

    ELK E: ElasticSearch 搜索引擎 存储 https://www.elastic.co/cn/downloads/elasticsearch L: Logstash 日志收集 http ...

  5. CentOS防火墙iptables使用

    1.1 企业安全优化配置原则 尽可能不给服务器配置外网ip ,可以通过代理转发或者通过防火墙映射.并发不是特别大情况有外网ip,可以开启防火墙服务高并发的情况,不能开iptables,会影响性能,利用 ...

  6. 洛谷P1020 导弹拦截 题解 LIS扩展题 Dilworth定理

    题目链接:https://www.luogu.com.cn/problem/P1020 题目大意: 给你一串数,求: 这串数的最长不上升子序列的长度: 最少划分成多少个子序列是的这些子序列都是不上升子 ...

  7. SqlBulkCopy批量插入和索引的关系

    .net中批量插入基本都用SqlBulkCopy,速度很快,但是这几天发现个问题,2000数据居然15s,百思不得其解.经过大量测试,发现过多的索引和索引碎片会严重影响插入速度,表的数据量大小反而不会 ...

  8. hutool BigExcelWriter 下的autoSizeColumnAll异常问题

    autoSizeColumnAll java.lang.IllegalStateException: Could not auto-size column. Make sure the column ...

  9. ACM北大暑期课培训第六天

    今天讲了DFA,最小生成树以及最短路 DFA(接着昨天讲) 如何高效的构造前缀指针: 步骤为:根据深度一一求出每一个节点的前缀指针.对于当前节点,设他的父节点与他的边上的字符为Ch,如果他的父节点的前 ...

  10. 1z0-062 题库解析5

    题目: Which three statements are true about Flashback Database? A. Flashback logs are written sequenti ...