day11(函数参数,函数对象,打散机制,函数嵌套调用)
一,复习
# 什么是函数:具体特定功能的代码块 - 特定功能代码块作为一个整体,并给该整体命名,就是函数 # 函数的优点:
# 1.减少代码的冗余
# 2.结构清晰,可读性强
# 3.具有复用性,开发效率高,维护成本低 # 如何定义一个函数:用def关键词来声明函数
'''
def fn(参数列表):
函数体
return 函数的返回值
'''
# -- 定义函数时,函数体不会被执行 | 函数必须先定义后使用 # 函数的四部分:
# 函数名:存放着函数的地址,是调用函数的依据
# 函数体:解决问题的代码块
# 参数列表:外界为内部提供数据的途径 - 内部需要外部的数据,就需要定义参数列表
# 返回值:将内部的结果返回给外部 # 函数的使用
# 1.通过函数名找到函数的地址
# 2.函数名() 来调用执行函数
# 3.得到函数执行的结果 - 返回值 def add(n1, n2):
return n1 + n2
add(10, 20) # 只执行的函数体
res = add(10, 20) # 执行的函数体,并拿到函数的执行结果
print(add(10, 20) + 100) # 执行的函数体,并拿到函数的执行结果,再使用 # 函数的分类
# 有无函数体:空函数 - pass填充 | 非空函数 - 有函数体 # 有无参数:
#无参函数 - 内部不需要外部数据
#有参函数 - 内部需要外部数据 # 有无返回值:
#不主动明确返回值的函数 - 系统主动在函数体末尾添加return
#主动明确返回值的函数 - 按需求明确return # 函数的返回值
# 没有return关键字的函数:不关系函数的返回值,但函数的返回值为None
# 有空return:不关系函数的返回值,但在特定条件下要主动结束函数,空return,函数的返回值为None
# return一个值:外界就可以接收到返回的一个值
# return多个值:外界用一个值接收,接收到的是元组 | 外界用多个值接收,接收的个数与返回的个数一定要统一(本质采用解压赋值) # return的作用:1.结束函数 2.携带内部参数给外部
二,今日内容
# 函数的参数: ****
# 函数对象 - 函数名:*****
# 函数的嵌套调用:***
三,形参与实参
# 参数介绍:
# 函数为什么要有参数:因为内部的函数体需要外部的数据
# 怎么定义函数的参数:在定义函数阶段,函数名后面()中来定义函数的参数
# 怎么使用函数的参数:在函数体中用定义的参数名直接使用 # 实参:有实际意义的参数
# -- 在函数调用的时候,()中传入的参数
# 形参:参数本身没有意义,有实参赋予形参值后,该形参就具备了意义
# 补充:有默认值的形参,在没有被实参赋值,具备的是自身意义,但一旦被实参赋值,意义同实参 - def add(n1, n2=2):
# -- 在定义函数的时候,()中出现的参数 # 形参范畴
def add(n1, n2): # 形参n1,n2在没有被实参赋值时,没有实际意义,被什么意义的实参赋值,就被赋予了什么意义
return n1 + n2 # 实参范畴
print(add('a', 'b')) # 实际的字符串
print(add(10, 20)) # 实际的数字
a = 200
b = 300
print(add(a, b)) # 存放实际数字的变量
四,形参是对实参的值拷贝
# 形参与实参可以重名,但是代表的是两个不同的变量 # 不可变类型,形参发生重指向,实参不变
def fn(num):
print('1>>>:', num) #
num = 20
print('2>>>:', num) # num = 10
fn(num)
print('3>>>:', num) # # 可变类型,形参发生值的内部变化,实参变,两个指向的是同一个地址
def func(ls):
print('1>>>:', ls) # [10]
ls.append(20)
print('2>>>:', ls) # [10, 20] ls = [10] func(ls)
print('3>>>:', ls) # [10, 20]
五,实参的分类
# 实参分为:1.位置实参 2.关键字实参 def fn(a, b):
print(a, b) # 1)拿实际值进行传参
fn(10, 20) # 10 => a | 20 => b # 2)拿位置实参进行传参:形参与实参进行位置一一对应,eg:1号位的实参一定传给1号位的形参
a = 100
b = 200
fn(a, b) # a:100 => a | b:200 => b
fn(b, a) # b:200 => a | a:100 => b # 3)拿关键字实参进行传参:指名道姓进行传参 - 传参的过程过指名道姓形参
# 明确:形参名目前为a和b
fn(a=1000, b=2000) # a:1000 => a | b:2000 => b
fn(b=2000, a=1000) # b:2000 => b | a:1000 => a
a = 666
b = 888
# 前面的是形参名,后面的是传递的实参名
fn(a=a, b=b) # a:666 => a | b:888 => b # 位置实参:一定按照位置,且个数要一一对应进行传参
# 关键字实参:指名道姓进行传参,个数一致位置可以改变进行传参 # 实参组合传参规则:必须先传位置实参,再传关键字实参
六, 形参的分类
# 六大分类:
# 1.无值位置形参(位置形参):可以被位置与关键字实参进行传参,必须传值 # 2.有值位置形参(默认形参):可以被位置与关键字实参进行传参,可以不用传参采用默认值 # 3.可变长位置形参(*args):可以接受前两个没有接收完位置实参,接收的个数可以为0~n个,0个是就是空元组 # 4.无值关键字形参(c):只能由关键字实参进行传参,必须传值 # 5.有值关键字形参(d = 10):只能由关键字实参进行传参,可以不用传参采用默认值 # 6.可变长关键字形参(**kwargs):接收4,5没有接收完的关键字实参,接收的个数可以为0~n个,0个是就是空字典 # 声明顺序:
# 位置形参:a -> 默认形参:b -> 可变长位置形参:args -> 有无默认值关键字形参:cde -> 可变长关键字形参:kwargs
def fn(a, b=10, *args, c, d=20, e, **kwargs): pass # 注意点:
# 1.可变长位置形参只能接受位置实参,要想被赋上值,前面的有值位置形参的默认值没有多大意义
# 2.args与kwargs是可变长形参的变量名,所以可以自定义,但约定俗成就用它俩 # 位置形参一定遵循:无值在前,有值在后
# 关键字形参顺序可以任意 # 常出现的组合
def f1(*args, **kwargs): pass def f2(a, b=10, **kwargs): pass
def f3(a, *args, **kwargs): pass def f4(a, *, x, **kwargs): pass
def f5(a, *args, x, **kwargs): pass # 使用法则:
# 1.所有位置形参全部采用位置实参进行传值
# 2.所有关键字形参全部采用关键字实参进行传值
# 3.不管位置还是关键字形参,全部按照顺序进行传参
七,打散机制
def fn(*args, **kwargs):
print(args)
print(kwargs) t = (1, 2, 3)
dic = {'a': 100, 'b': 200, 'c': 300} # *单列容器 会打散单列容器(字符串,列表,元组,集合)
# **双列容器 会打散双列容器(字典)
fn(1, 2, 3, a=100, b=200, c=300) # (1, 2, 3) {'a': 100, 'b': 200, 'c': 300}
fn(*t, **dic) # (1, 2, 3) {'a': 100, 'b': 200, 'c': 300}
fn(*(1, 2, 3), **{'a': 100, 'b': 200, 'c': 300}) # (1, 2, 3) {'a': 100, 'b': 200, 'c': 300} # 字符串也可以被打散
fn(*'abc') # ('a', 'b', 'c') {}
print(*'abc') # a b c
八,函数的嵌套调用
# 函数的嵌套调用:在一个被调用的函数内部调用另一个函数
# -- 复用之前已定义好的函数功能 - 功能有重叠 def a():
b() def b():
pass a() # a的调用必须在b的声明之后,原因a中要使用b # 注意:在提前声明的函数中可以嵌套调用之后声明的函数,
# 但是本函数的调用必须在嵌套被调用的函数声明之后 # 应用场景
# 求两个数的大者
def max_two(a, b):
if a > b:
return a
return b
print(max_two(100, 20)) # 求三个数的大者
# def max_three(a, b, c):
# # if b < a > c:
# # return a
# # if a < b > c:
# # return b
# # if a < c > b:
# # return c
def max_three(a, b, c):
max_num = max_two(a, b)
return max_two(max_num, c)
# print(max_three(20, 10, 5)) # 求四个数的大者
def max_four(a, b, c, d):
max_num = max_three(a, b, c)
return max_two(max_num, d)
day11(函数参数,函数对象,打散机制,函数嵌套调用)的更多相关文章
- Day04:函数参数、对象、嵌套、闭包函数和装饰器
上节课复习: 1.什么是函数 函数就是具备某一功能的工具 2.为何用函数 1.程序的组织结构和可读性 2.减少代码冗余 3.扩展性强 ...
- agruments应用——求出函数参数的总合&&css函数——设置/读取对象的属性&&当前输入框高亮显
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- python函数:函数参数、对象、嵌套、闭包与名称空间、作用域
今天的内容整理共有5部分 一.命名关键字参数 二.函数对象 三.函数的嵌套 四.名称空间与作用域 五.闭包函数 一.命名关键字参数 # 命名关键字参数: 在定义函数时,*与**之间参数称之为命名关键字 ...
- python基础-4 函数参数引用、lambda 匿名函数、内置函数、处理文件
上节课总结 1.三元运算 name=“name1”if 条件 else “name2” 2.深浅拷贝 数字.字符串 深浅,都一样 2.其他 浅拷贝:只拷贝第一层 深拷贝:不拷贝最后一层 3.set集合 ...
- javascript 在一个函数参数中包含另一个函数的引用
javascript函数的参数包含另一个函数的情形: <script> //b函数的参数func为另一个函数 function b(a, func) { alert(a); //调用参数 ...
- c++函数参数或返回值为函数指针
C++中函数指针的形式为:返回值类型 + 参数类型,函数没有值类型,但是却可以声明函数的指针,因为函数是可寻址的,存放在内存中的代码段,可以从指针访问. 函数指针可以声明为: void (*pF)(v ...
- 11、Python函数基础(定义函数、函数参数、匿名函数)
函数先定义函数,后调用 一.定义函数: 1.简单的规则: 函数代码块以 def 关键词开头,后接函数标识符名称和圆括号 (). 任何传入参数和自变量必须放在圆括号中间,圆括号之间可以用于定义参数. 函 ...
- day12 函数的嵌套调用 闭包函数,函数对象
函数嵌套: 函数嵌套: 嵌套指的是,一个物体包含另一个物体,函数嵌套就是一个函数包含另一个函数 按照函数的两个阶段 嵌套调用 指的是在函数的执行过程中调用了另一个函数,其好处可以简化外层大函数的代码, ...
- Day8 函数指针做函数参数
课堂笔记 课程回顾 多态 virtual关键字 纯虚函数 virtual func() = 0; 提前布局vptr指针 面向接口编程 延迟绑定 多态的析构函数的虚函数. ...
- Java获取函数参数名称
原理 编译之后的class文件默认是不带有参数名称信息的,使用 IDE 时,反编译jar包得到的源代码函数参数名称是 arg0,arg1......这种形式,这是因为编译 jar 包的时候没有把符号表 ...
随机推荐
- Python就业指导
一年一度的金三银四招聘旺季又要到了,最近有很多同学希望我能给他们一些关于python的就业指导:之前出过一期关于java的就业指导,但是并不是很完善,所以希望这期关于python的就业指导能够很全面很 ...
- 【神经网络篇】--基于数据集cifa10的经典模型实例
一.前述 本文分享一篇基于数据集cifa10的经典模型架构和代码. 二.代码 import tensorflow as tf import numpy as np import math import ...
- 实体继承与@Builder注解共存
在面向对象的设计里,继承是非常必要的,我们会把共有的属性和方法抽象到父类中,由它统一去实现,而在进行lombok时代之后,更多的打法是使用@Builder来进行对象赋值,我们直接在类上加@Builde ...
- .NET Core 的缓存篇之MemoryCache
前言 对于缓存我们都已经很熟悉了,缓存分为很多种,浏览器缓存.试图缓存.服务器缓存.数据库缓存等等一些,那今天我们先介绍一下视图缓存和MemoryCache内存缓存的概念和用法: 视图缓存 在老的版本 ...
- 目标检测 IOU(交并比) 理解笔记
交并比(Intersection-over-Union,IoU): 目标检测中使用的一个概念 是产生的候选框(candidate bound)与原标记框(ground truth bound)的交叠率 ...
- Selenium的发展历史及原理
目录 1. selenium1.0的产生 2. webdriver的产生 3. selenium和webdriver的合并 4. selenium3.0的产生 1. selenium1.0的产生 为什 ...
- 图像检索(4):IF-IDF,RootSift,VLAD
TF-IDF RootSift VLAD TF-IDF TF-IDF是一种用于信息检索的常用加权技术,在文本检索中,用以评估词语对于一个文件数据库中的其中一份文件的重要程度.词语的重要性随着它在文件中 ...
- 如何探测网络设备ACL规则
探测网络设备ACL规则 背景:在互联网企业的生产网络中,往往在网络入口处的网络设备上会有成千上万条ACL策略,这么多的ACL导致了网络管理员很难彻底梳理清楚其中的逻辑关系,从而不知道到底对外开放了哪些 ...
- js + 加号 报错,IIS 配置
一.问题描述: 1开发环境完全没有问题: 2 build 后生成的js脚本,带有+号. 程序发布到IIS后,带加+号js脚本报错. 二.解决方案 1 修改build规则,让它不产生特殊符号. 能力有 ...
- linux的一些命令,面试经常碰到的
1 查询所有java进程ps -A | grep java解释一下这个命令的意思,ps 是查看系统当前进程的命令,参数 -A(注意,是大写,linux中是区分大小写的)是显示所有程序,| 这个是管道符 ...