本文实例讲述了Python函数基础用法。分享给大家供大家参考,具体如下:
一、什么是命名关键字参数?
格式: 在*后面参数都是命名关键字参数。
特点:
1、约束函数的调用者必须按照Kye=value的形式传值。
2、约束函数的调用者必须用我们指定的Key名。
1
2
3
4
5
6
|
def auth( * args,name,pwd): print (name,pwd) auth(pwd = '213' ,name = 'egon' ) def register(name,age): print ( type (name), type (age)) register( 123 ,[ 1 , 2 , 3 ]) |
以上输出:
egon 213
<class 'int'> <class 'list'>
二、函数的嵌套
1、函数的嵌套调用:在函数内又调用了其他函数
1
2
3
4
5
6
7
8
9
10
|
def max2(x,y): if x > y: return x else : return y def max3(x,y,z): res1 = max (x,y) res2 = max (res1,z) return res2 print (max3( 88 , 99 , 100 )) |
以上输出:
100
2、函数的嵌套定义:在函数内又定义其他函数。
1
2
3
4
5
6
7
8
9
|
def func1(): print ( 'from func1' ) def func2(): #func2=内存地址 print ( 'from func2' ) print (func2) #<function func1.<locals>.func2 at 0x0000024907A098C8> func2() func2() func2() func1() |
以上输出:
from func2
from func2
from func2
三、函数的名称空间
1、名称空间:存放名字与值绑定关系的地方
1
2
3
|
x = 888888888 def func(): pass |
2、名称空间分为三类
(1)内置名称空间:存放python解释器自带的名字,在解释器启动时就生效,解释器关闭则失效。
(2)全局名称空间:文件级别的名字,在执行文件的时候生效,在文件结束或者在文件执行期间被删除则失效。
1
2
3
4
5
6
7
8
9
10
|
x = 1 def f1(): def f2(): print (x) f2() f1() if 10 > 3 : y = 33333 while True : xxxxx = 123123123 |
以上输出:
1
(3)局部名称空间:存放函数自定义的名字(函数的参数以及函数内的名字都存放与局部名称空间),在函数调用时临时生效,函数结束则失效。
注意:
加载顺序:内置名称空间-------->>全局名称空间------->>>局部名称空间
查找名字:局部名称空间-------->>全局名称空间------->>>内置名称空间
1
2
3
4
5
6
7
|
def f1(): # len=1 def f2(): # len=2 print ( len ) f2() f1() |
以上输出:
global
3、作用域
全局作用域:包涵的是内置名称空间与全局名称空间的名字。
特点:
- (1)在任何位置都能够访问的到
- (2)该范围内的名字会伴随程序整个生命周期
局部作用域:包含的是局部名称空间的名字
特点:
- (1)只在函数内使用
- (2)调用函数时生效,调用结束失效
四、函数对象
1、函数在python中是第一类对象
(1)可以被引用
1
2
3
4
5
6
|
x = 1 y = x def bar(): print ( 'from bar' ) f = bar f() |
以上输出:
from bar
(2)可以当做参数传入
1
2
3
4
|
x = 1 def func(a): print (a) func(x) |
以上输出:
1
(3)可以当做函数的返回值
代码(1)
1
2
3
4
5
|
x = 1 def foo(): return x res = foo() print (res) |
以上输出:
1
代码(2)
1
2
3
4
5
6
7
8
|
def bar(): print ( 'from bar' ) def foo(func): #func=<function bar at 0x00000225AF631E18> return func #return <function bar at 0x00000225AF631E18> # print(bar) f = foo(bar) #f=<function bar at 0x00000225AF631E18> # print(f) f() |
以上输出:
from bar
(4)可以当做容器类型的元素
1
2
3
4
5
6
7
8
9
10
|
x = 1 l = [x,] print (l) def get(): print ( 'from get' ) def put(): print ( 'from put' ) l = [get,put] # print(l) l[ 0 ]() |
以上输出:
[1]
from get
注意:
1、 func可以被引用
1
|
f = func |
2、func可以当做参数传给x
3、func还可以当做返回值
4、可以当做容器中类型的元素
函数查询登录功能的引用:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
def auth(): print ( '请登录:' ) def reigster(): print ( '注册:' ) def search(): print ( '查看:' ) def transfer(): print ( '转账' ) def pay(): print ( '支付' ) dic = { '1' :auth, '2' :reigster, '3' :search, '4' :transfer, '5' :pay } def interactive(): while True : print ( ''' 1 认证 2 注册 3 查看 4 转账 5 支付 ''' ) choice = input ( '请输入编号:' ).strip() if choice in dic: dic[choice]() else : print ( '非法操作' ) interactive() |
五、闭包函数
闭:指的是定义在函数内部的函数
作用域关系,在函数定义阶段就规定死了,与调用位置无关
1
2
3
4
5
6
7
8
9
10
11
|
def outter(): x = 2 def inner(): # x=1 print ( 'from inner' ,x) return inner f = outter() #f=inner def foo(): x = 1111111111111111111111111111 f() foo() |
以上输出:
from inner 2
1、闭包函数:
(1)定义在函数内部的函数
(2)并且该函数包含对外部函数作用域中名字的引用,该函数就称为闭包函数
了解:
为函数体传值的方式
方式一:将值以参数的形式的传入
利用爬虫获取网站的源代码:
1
2
3
4
5
6
|
import requests: def get(url): response = requests.get(url) if response.status_code = = 200 : print (response.text) get( 'https://www.baidu.com' ) |
方式二
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
import requests import time def outter(url): #url='https://www.baidu.com' # url='https://www.baidu.com' def get(): response = requests.get(url) if response.status_code = = 200 : print (response.text) return get baidu = outter( 'https://www.baidu.com' ) python = outter( 'https://www.python.org' ) baidu() print ( '=====================>' ) time.sleep( 3 ) baidu() |
希望本文所述对大家Python程序设计有所帮助。
原文链接:https://www.cnblogs.com/lyox/p/8665386.html