python基础篇_003_函数
python中的函数
1.函数的目的
.避免代码冗余
.增强可读性
2.函数的定义与调用
# 定义函数 使用关键字def
"""
1.定义函数:
def 函数名():
函数体
""" def sayhello():
print("hello") """
2.调用函数:
函数名()
"""
sayhello()
3.函数返回值
# 函数的返回值
"""
1.什么都不写的情况下没有返回值
2.return # 没有返回值 # 结束函数
3.return None
4.return 变量
""" def say_hello1():
print("hello")
print(say_hello1()) def say_hello2():
print("hello")
return
print(say_hello2()) def say_hello3():
print("hello")
return None
print(say_hello3()) def say_hello4():
print("hello")
return "hello"
print(say_hello4())
序列解压
# 序列的解压
a, b, c, d = (1, 2, 3, 4)
print(a, b, c, d) # 1 2 3 4 a, _, _, d = (1, 2, 3, 4) print(a, d) # 1 4 a, *_ = (1, 2, 3, 4)
*_, d = (1, 2, 3, 4)
print(a, d) # 1 4
# 字典、列表、集合同样适用
a, b = {'name': 'eva', 'age': 18}
print(a, b) # age name
多个返回值
def demo():
"""多个返回值情况"""
return 1, 2, 3, 'a' """多个返回值,用一个变量接收时,得到的是一个元祖"""
a = demo()
print(a) # (1, 2, 3, 'a') """适用同等个数的变量接收,个数不相同,报错"""
a, b, c, d = demo()
print(a, b, c, d)
4.函数的参数
实参与形参
"""
1.定义函数使用的是形参
2.调用函数使用的是实参
"""
传参
实参角度
1.按照位置传参
def demo(x, y):
print(x, y) demo(10, 20)
2.按照关键字传参
def demo(x, y):
print(x, y) demo(y=10, x=20)
3.位置与关键字混用(位置参数必须在关键字参数的前面)
def demo(x, y):
print(x, y) demo(10, y=20) # 按照顺序
形参角度 : 位置参数必须传值
默认参数
def info(name, sex='male'):
"""将变化值较小的设置成默认参数"""
print(name, sex) # 调用函数时。默认参数可以不传值
info('a')
info('a', 'female')
def info(name, li=[]):
"""陷阱:默认参数是一个可变数据类型"""
li.append(name)
print(li) info('a') # ['a']
info('b') # ['a', 'b']
区别其他语言:
package com.zzz object Test {
def demo(name: String, list: List[String] = Nil): List[String] = {
return name :: list
} def main(args: Array[String]): Unit = {
val a = demo("a")
val b = demo("b")
print(a, b) //(List(a),List(b))
}
}
动态参数
"""
动态参数:
按位置传值多余的参数都由args统一接收,保存成一个元组的形式
""" def to_sum(*args):
sum = 0
print(args)
for i in args:
sum += i
return sum a = to_sum(1, 2, 3)
print(a)
# (1, 2, 3)
#
b = to_sum(1, 2, 3, 4)
print(b) # (1, 2, 3, 4)
# # 接收k-v类型的参数 def info(**kwargs):
print(kwargs)
print(kwargs['name'], kwargs['sex']) info(name='a', sex='b')
# {'name': 'a', 'sex': 'b'}
# a b
5.命名空间及作用域
"""
1.python解释器开始执行之后,就在内存中开辟了一个空间
2.每当遇到一个变量的时候,就把变量名和值之间的对应关系记录下来
3.当遇到函数定义的时候解释器只是象征性的将函数名读入内存,表示知道这个函数的存在了,至于函数内部的变量和逻辑解释器根本不关心
4.等执行到函数调用的时候,python解释器会再开辟一块内存来存储这个函数里的内容,
这个时候,才关注函数里面有哪些变量,而函数中的变量会存储在新开辟出来的内存中。
函数中的变量只能在函数的内部使用,并且会随着函数执行完毕,这块内存中的所有内容也会被清空。 创建的存储“变量名与值的关系”的空间叫做全局命名空间,在函数的运行中开辟的临时的空间叫做局部命名空间
"""
# globals和locals方法
print(globals())
print(locals()) # 这中情况下,两种是一样的 def func():
a = 12
b = 20
print(locals()) # {'b': 20, 'a': 12}
print(globals()) func()
#global 关键字
a = 10
def func():
global a
a = 20 print(a) #10
func()
print(a) #20
6.函数嵌套
def f1():
print("in f1")
def f2():
print("in f2") f2()
f1()
"""
nonlocal关键字
# 1.外部必须有这个变量
# 2.在内部函数声明nonlocal变量之前不能再出现同名变量
# 3.内部修改这个变量如果想在外部有这个变量的第一层函数中生效
""" def f1():
a = 1 def f2():
a = 2 f2()
print('a in f1 : ', a) f1() # a in f1 : 1 def f1():
a = 1 def f2():
nonlocal a
a = 2 f2()
print('a in f1 : ', a) f1() # a in f1 : 2
7.函数名的本质
"""函数名本质上就是函数的内存地址
1.可以被引用
2.可以被当作容器类型的元素
3.可以当作函数的参数和返回值
""" def f1():
return '' f = f1()
print(f) def f2():
return '' def f3():
return ['a', 'b'] li = [f1(), f2(), f3()]
a = li[2]
print(a) dict1 = {'f1': f1, 'f2': f2, 'f3': f3}
b = dict1['f1'] # <function f1 at 0x0000000001420378>
c = dict1['f1']() #
print(b, c) dict1 = {'f1': f1(), 'f2': f2(), 'f3': f3()}
d = dict1['f1'] #
print(d)
print('---------------') def f5():
return f1()
a = f5()
print(a) #
8.闭包
内部函数包含对外部作用域而非全剧作用域名字的引用,该内部函数称为闭包函数
def func():
name = 'eva'
def inner():
print(name)
"""
想要拿到函数内部的变量和函数,返回变量跟函数
闭包函数用途
在函数外部调用函数内部的函数
""" def func():
name = 'zhangsan' def inner():
print(name) return inner f = func()
f()
判断是否是闭包函数方法__closure__
# 输出的__closure__有cell元素 :是闭包函数
def f1():
name = 'zhangsan' def inner():
print(name) print(inner.__closure__) # (<cell at 0x0000000000E591C8: str object at 0x00000000008F37B0>,)
return inner f = f1()
f() # 输出的__closure__为None :不是闭包函数
name = 'zhangsan' def f2():
def inner():
print(name) print(inner.__closure__) # 判断inner函数是不是闭包函数 None
return inner f2 = f2()
f2()
def f1():
money = 1000
def f2():
name = 'zhangsan'
def f3():
print(name,money)
return f3
return f2 f = f1()
i = f()
i()
python基础篇_003_函数的更多相关文章
- python 基础篇 11 函数进阶----装饰器
11. 前⽅⾼能-装饰器初识本节主要内容:1. 函数名的运⽤, 第⼀类对象2. 闭包3. 装饰器初识 一:函数名的运用: 函数名是一个变量,但他是一个特殊变量,加上括号可以执行函数. ⼆. 闭包什么是 ...
- Python基础篇(初始函数)
Python初始函数: 一.什么是函数 1.我们到目前为止, 已经可以完成一些软件的基础功能了. 那么我们来完成这样一个功 能: 约x: print("拿出手机") print(& ...
- python 基础篇 匿名函数
匿名函数基础 首先,什么是匿名函数呢?以下是匿名函数的格式: lambda argument1, argument2,... argumentN : expression 我们可以看到,匿名函数的关键 ...
- python 基础篇 自定义函数
多态 我们可以看到,Python 不用考虑输入的数据类型,而是将其交给具体的代码去判断执行,同样的一个函数(比如这边的相加函数 my_sum()),可以同时应用在整型.列表.字符串等等的操作中. 在编 ...
- python 基础篇 10 函数进阶
本节主要内容:1. 函数参数--动态传参2. 名称空间, 局部名称空间, 全局名称空间, 作⽤域, 加载顺序.3. 函数的嵌套4. gloabal, nonlocal关键字 ⼀. 函数参数--动态传参 ...
- python 基础篇 09 函数初识
<<<<<<<<<<<<<<<------------------------------函 ...
- Python基础篇(三)_函数及代码复用
Python基础篇_函数及代码复用 函数的定义.使用: 函数的定义:通过保留字def实现. 定义形式:def <函数名>(<参数列表>): <函数体> return ...
- python基础篇之进阶
python基础篇之进阶 参考博客:http://www.cnblogs.com/wupeiqi/articles/5115190.html python种类 1. cpython 使用c解释器生产 ...
- python基础篇(六)
PYTHON基础篇(六) 正则模块re A:正则表达式和re模块案例 B:re模块的内置方法 时间模块time A:时间模块的三种表示方式 B:时间模块的相互转换 随机数模块random A:随机数模 ...
随机推荐
- Flask 构建微电影视频网站(四)
后台管理 实现后台管理系统使用flask sqlalchemy结合mysql数据库进行增删改查操作.分页的使用.路由装饰器定义.模板中变量调用.登录会话机制.上传文件.flask wtforms表单使 ...
- (五)qt资源文件
// 规则: :+添加的前缀/+文件名 ui->actionSave_as->setIcon(QIcon(":/new/Image/face.png"));
- Redis的Cluster配置
Redis的Cluster配置 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.安装Redis并启动 1>.修改Redis的配置文件(本实验只有三个节点) [root@no ...
- Fiddler--Composer
Composer选项卡支持手动构建和发请求:也可以在Session列表中拖拽Session放到Composer中,把该Session的请求复制到用户界面: 点击"execute"按 ...
- GIT-windows系统部署git服务器
windows系统部署git服务器 因为需要所以就来利用IIS(Internet Information Service )来进行搭建. 进入正文: 不管你是什么win7.win8.win8.1还是w ...
- LFYZ-OJ ID: 1028 背包问题
背包问题 题目描述 简单的背包问题.设有一个背包,可以放入的重量为s.现有n件物品,重量分别为w1,w2-,wn,(1≤i≤n)均为正整数,从n件物品中挑选若干件,使得放入背包的重量之和正好为s.找到 ...
- 解决 IIS 反向代理ARR URLREWRITE 设置后,不能跨域跳转 return Redirect 问题
1.选择iis根节点,点击ARR 2.选择代理设置 3.去掉reverse rewrite host in response headers的勾选,点击应用即可
- 第六节:WebApi的部署方式(自托管)
一. 简单说明 开篇就介绍过WebApi和MVC相比,其中优势之一就是WebApi可以不依赖于IIS部署,可以自托管,当然这里指的是 .Net FrameWork 下的 WebApi 和 MVC 相比 ...
- Promise异步操作
Promise是es6中新增加的类(new Promise),目的为了管理JS中异步编程,也叫“Promise”设计模式 Promise用来解决异步问题.本身是同步的,只是用来管理异步编程的一种模式 ...
- v-charts 和 websocket实现数据展示动态推送
v-charts https://v-charts.js.org/#/ ELEMENT力作: 在使用 echarts 生成图表时,经常需要做繁琐的数据类型转化.修改复杂的配置项,v-charts 的出 ...