python之函数
来源:互联网 发布:install ubuntu reboot 编辑:程序博客网 时间:2024/06/05 20:04
函数(python的乐高积木一)
思维导图:
内置函数(BIF,built-in function)
min,max,sum,zip,abs,
int,float,str,list,tuple,bool,isinstance
In [56]: bool(1)Out[56]: TrueIn [57]: bool("")Out[57]: False
函数实质上是一个变量;函数名是一个指向函数对象的引用,完全可以把函数赋值给一个变量,相当于给这个函数起了个别名;
In [59]: a = abs # a变量指向abs函数In [60]: a(-1) # 可以通过a实现abs的功能;Out[60]: 1In [61]: abs(-1)Out[61]: 1
定义与调用函数
def 函数名([形式参数]): 函数体 # 函数要执行的程序 return 返回值 # 如果没有return返回,默认返回值为None;函数名([实参])注意:有返回值的函数,print fun(),可以打印出返回值;
函数的返回值
- 在函数中,一旦遇到return关键字,函数就执行结束;
- 函数返回值只能返回一个,如果想间接返回多个值,返回值实际是一个元组;
def maxSum(num1,num2,num3): print num2 return max(num1,num2,num3),sum([num1,num2,num3]) num1 += 2 print num1print type(maxSum(1,4,2))print maxSum(1,4,2)
函数的参数传值
必选参数:形参与实参的个数必须相同,否则直接报错;
默认参数:在定义函数时,给形参一个默认值,必须要是不可变对象。有多个参数时,变化大的放前面,变化小的方后面;必选参数在前,默认参数在后。
def sum(n=2):可变参数:传入的参数个数是可变的,可以是1-n个,也可以是0个;一般实参中用*num来表示可变参数;
num接收的是一个元组(tuple);
def sum(num,n=2): sum=0 sum+=num**n return sumprint sum(5)
- 关键字参数:以字典存储
函数在进行关键字传参时,函数以**来接收,并且关键字参数为可选项
必选参数必须传递值,不然会报错!
- 参数的顺序为:必选参数,默认参数,可变参数,关键字参数,顺序错误时,会报错!
变量的作用域
- 全局参数:在函数外定义的函数
- 局部参数:在函数内部定义的函数;
- global:声明局部变量为全局变量;
global namename = "westos"
解包
在使用可变参数传值时,将多个实参以元组的形式存储。
当将一个序列传递时给可变参数时,将序列作为一个整体存储在元组中
想要使序列中个元素分别存储在元组中,需要在参数传递时对序列进行拆分:*+序列可实现
关键字参数时:
未解包:
解包后:
文档化函数
使用func._doc_ 可查看func函数的注释内容。
等价于help(func)
使用自己写的函数hello
1>import hello
(hello存在两个文档,hello,hello.py)
2>编写帮助文档hello.world
3>使用help(hello.world)来查看hello的帮助文档。
阅读全文
0 0
- python函数之filter函数
- Python之工厂函数
- python之daemon函数
- python笔记之函数
- Python学习之函数
- python学习之函数
- Python学习之函数
- python之enumerate函数
- Python之函数
- Python 函数之seek
- python之函数
- Python学习之函数
- python函数之strip()
- Python之Split函数
- python之len函数
- 自学Python之函数
- python学习之函数
- python系列之 - 函数
- Python中的sorted函数以及operator.itemgetter函数
- VB.NET + EmguCV实现PCA降维
- HTML5的认知与理解
- 输入输出格式练习
- go context专题(三)- context 工作机制和代码分析
- python之函数
- JSP之WEB服务器:Apache与Tomcat的区别 ,几种常见的web/应用服务器
- R语言统计分析
- HDU3836(强联通分量+思维)
- 里程计、推算定位与视觉里程计
- [WebGIS] 地图坐标偏移问题
- css基础(3)
- Android设备网络压力测试
- Linux下Hadoop2.7.1集群环境的搭建(超详细版)