1.15 Python基础知识 - 函数
函数是可重用的程序代码段。
一、函数的声明和调用
声明格式:
def 函数名([形参列表]):
函数体
调用格式:
函数名([实参列表])
函数名:是一种标识符,命名规则为全小写字母,可以使用下划线增加可阅读性。
形参列表:表示传递给该函数的值或变量引用,(用圆括号括起来,并用逗号隔开,可能为空)
函数体:函数执行的代码块
实参列表:实际传入的参数值
示例代码:
def my_add(a,b): # 声明函数,返回值
return a+b def my_print(msg): # 声明函数,无返回值
print(msg) c = my_add(11,22) # 调用函数
my_print(c) #调用函数 # 输出结果 33
二、参数的传递
1、形式参数和实际参数
形参:声明函数时声明的参数,即形式参数
实参:调用函数时,提供函数需要的参数的值,即实际参数
实际参数默认按位置顺序依次传递给形式参数。
2、可选参数(参数默认值)
在声明函数时,如果希望函数的一些参数是可选的,可以在声明函数时为这些参数指定默认值。调用该函数时,如果没有传入对应的实参值,则函数使用声明时指定的默认参数值。
示例代码:
def my_add(a,b=12):
return a+b def my_print(msg):
print(msg) c = my_add(11)
my_print(c) # 输出结果 23
注:必须先声明没有默认值的形参,然后声明有默认值的形参,因为函数调用时,默认是按位置传递实际参数值的。
3、位置参数和命名参数(关键字参数)
位置参数:函数调用时,默认按位置顺序传递形参的参数
关键字参数:按名称指定传入的参数,优点:一、参数按名称意义明确;二、传递的参数与顺序无关;三、如果有多个可选参数,可以选择某个参数值
示例代码:
def my_add(a,b=12,c=23):
return a+b+c def my_print(msg):
print(msg) c = my_add(11,c=11) # 11为位置参数,c=11为关键字参数
my_print(c) # 输出结果 34
4、可变参数(不固定参数,或参数组)
在声明函数时,通过带星的参数,如*args,允许向函数传递可变(任意)数量的实参,在调用时,这些参数会被收集为一个元组。
在声明函数时,也可以通过带双星的参数,如**kwargs,允许向函数传递可变数量的实参,在调用时,这些参数会被收集为一个字典。
示例代码1:
def my_add(*args):
return args def my_print(msg):
print(msg) c = my_add(11,12,13,14)
my_print(c) # 输出结果 (11, 12, 13, 14)
示例代码2:
def my_add(**kwargs):
return args def my_print(msg):
print(msg) c = my_add(a=11,b=12,c=13,d=14)
my_print(c) # 输出结果
{'a': 11, 'b': 12, 'c': 13, 'd': 14}
示例代码3:
def my_add(*args,**kwargs):
return args,kwargs def my_print(msg):
print(msg) c = my_add(2,3,4,a=11,b=12,c=13,d=14)
my_print(c) # 输出结果
((2, 3, 4), {'a': 11, 'b': 12, 'c': 13, 'd': 14})
三、函数的返回值
函数可以返回值,即在函数体中使用return语句从函数返回一个值,并跳出函数。如果需要返回多个值,则可以返回一个元组。
示例:
def f1():
return 1,2,3 a=f1()
print(a) # 输出结果
(1, 2, 3)
四、变量的作用域
变量声明的位置不同,其可被访问的范围也不同。变量的可被访问范围称为变量的作用域。变量按其作用域大致可以分为:全局变量、局部变量和类型成员变量
全局变量:在函数和类定义以外声明的变量
局部变量:在函数体中声明的变量(包括函数参数)
类成员变量:在类中声明的变量,包括静态变量和实例变量。
1.15 Python基础知识 - 函数的更多相关文章
- Python基础知识总结笔记(四)函数
Python基础知识总结笔记(四)函数python中的函数函数中的参数变量作用域偏函数PFA递归函数高阶函数BIFs中的高阶函数匿名函数lambda闭包Closure装饰器Decorator函数式编程 ...
- python基础知识小结-运维笔记
接触python已有一段时间了,下面针对python基础知识的使用做一完整梳理:1)避免‘\n’等特殊字符的两种方式: a)利用转义字符‘\’ b)利用原始字符‘r’ print r'c:\now' ...
- 八. Python基础(8)--函数
八. Python基础(8)--函数 1 ● 函数返回布尔值 注意, 自定义的函数也可以是用来作逻辑判断的, 例如内置的startswith()等函数. def check_len(x): ' ...
- python基础知识部分练习大全
python基础知识部分练习大全 1.执行 Python 脚本的两种方式 答:1.>>python ../pyhton.py 2. >>python.py #必须在首行 ...
- python基础知识的学习和理解
参考链接:https://github.com/yanhualei/about_python/tree/master/python_learning/python_base python基础知识笔 ...
- Python开发【第二篇】:Python基础知识
Python基础知识 一.初识基本数据类型 类型: int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位 ...
- python基础——filter函数
python基础——filter函数 Python内建的filter()函数用于过滤序列. 和map()类似,filter()也接收一个函数和一个序列.和map()不同的是,filter()把传入的函 ...
- python 基础知识(一)
python 基础知识(一) 一.python发展介绍 Python的创始人为Guido van Rossum.1989年圣诞节期间,在阿姆斯特丹,Guido为了打发圣诞节的无趣,决心开发一个新的脚本 ...
- python基础知识讲解——@classmethod和@staticmethod的作用
python基础知识讲解——@classmethod和@staticmethod的作用 在类的成员函数中,可以添加@classmethod和@staticmethod修饰符,这两者有一定的差异,简单来 ...
随机推荐
- 关于viewport详解
- How Javascript works (Javascript工作原理) (十二) 网络层探秘及如何提高其性能和安全性
个人总结:阅读完这篇文章需要20分钟,这篇文章主要讲解了现代浏览器在网络层传输所用到的一些技术, 应当对 window.performance.timing 这个API所有了解. 这是 JavaScr ...
- 【Uva 10285】Longest Run on a Snowboard
[Link]: [Description] 在一个r*c的格子上; 求最长的下降路径; [Solution] 记忆化搜索; f[x][y]表示从(x,y)这个格子往下还能走多远; 因为是严格递增,所以 ...
- Struts(18)标签
控件标签 Struts 2 的标签有一组标签.更easy控制流程页面运行.下面是重要的Struts2控制标签列表: if /else 标签: 这些标签运行可在每一种语言找到的一种基本条件流程. 'If ...
- 为什么我们须要复杂的password
前两天我打开邮箱一看.收到公司1331一封要求改动邮箱password的邮件. 为什么我们须要一个复杂的password呢?尽管我一直以来设置的password都非常复杂.可是公司这次要求改动pass ...
- Android 4.4 Fence在SurfaceFlinger中的应用
网上关于android.fence的资料好少啊.差点儿没有,可是这个机制又在GUI系统中起着关键的数据,于是自己通读源代码和凝视.与大家分享下Fence究竟是怎么回事? Fence即栅栏.栅栏的角色与 ...
- HDU - 2254 奥运 (求等比数列和)
Description 北京迎来了第一个奥运会,我们的欢呼声响彻中国大地,所以今年的奥运金牌 day day up! 比尔盖兹坐上鸟巢里,手里摇着小纸扇,看的不亦乐乎,被俺们健儿的顽强拼搏的精神深深的 ...
- 【Django】AJAX
目录 JSON 序列化 stringify 反序列化 parse JSON与XML对比 AJAX简介 AJAX常见应用场景 jQuery实现AJAX JS实现AJAX AJAX请求设置csrf_tok ...
- web知识—协议
web使用超文本传输协议(HTTP,HyperText Transfer Protocol)进行通信.http在1990年左右出现,现在有0.9/1.0/1.1三个版本.在早期的互联网中的一些协议只能 ...
- PHP防止Xss攻击
mysql_real_escape_string() 所以得SQL语句如果有类似这样的写法:"select * from cdr where src =".$userId; 都要改 ...