简明python教程 --C++程序员的视角(二):函数及作用域
函数通过def
关键字定义。def关键字后跟一个函数的标识符名称,然后跟一对圆括号。圆括号之中可以包括一些变量名,该行以冒号结尾。接下来是一块语句,它们是函数体。
函数的基本概念
1 位置:从左往右进行匹配(默认方式)
2 关键字参数:通过参数名进行匹配
func(name = value)
3 默认参数:为没有传入值的参数定义参数值
def func(name = value)
4 打包参数:(函数)收集任意多参数位置参数def func(*name)或关键字参数def func(**name)
5 解包参数:(调用者)传递任意多(位置/关键字)参数位置参数func(*name)或关键字参数func(**name)
在不能预测将要传入参数的数目时,是很方便的,如min()
作用域的基本概念
global并不是类型的声明,而是命名空间的声明
全局变量在函数内被赋值,必须经过声明
global X;X += 1或者import thismod;thismod.X += 1全局变量名在函数的内部引用,可以不经过声明一个模块文件一旦被导入了,其全局变量也就变成了这个模块对象的一个属性:导入者自动得到了全局变量的访问权。但是别直接修改另一个文件中的变量。
文件间进行通信的最好办法是通过调用函数,传递参数,然后得到返回值。可以使用accessor函数管理这种变化。
# first.py
X = 99def setX(new)
global X
X = new
# second.py
函数内部被赋值的变量名,默认为本地变量 | 赋值操作:=语句,import语句,def语句,参数传递 L.append(X)并不会将L划分为本地变量,而L = X却可以 |
global声明了一个模块级的变量并被赋值 | |
委任一个单个模块文件去定义所有的全局变量 | 全局变量的值取决于函数调用的顺序,而函数自身是任意顺序进行排列的,会引发问题, |
最小化文件间变量的修改 |
函数定义
写在文件中没有问题:
不过在交互式中新手会。。。
函数形参
参数在函数定义的圆括号对内指定,用逗号分割。
(虽然一直很想要这样的字符串处理方式!但是作为一个C++程序员,不太习惯不打括号改打冒号,并且真心每次都很想打分号= =)
局部变量
在函数内改变局部变量x
的值的时候,在主块中定义的x
不受影响。结果:
使用global语句
如果你想要为一个定义在函数外的变量赋值,那么你就得告诉Python这个变量名不是局部的,而是 全局 的。我们使用global
语句完成这一功能。没有global
语句,是不可能为定义在函数外的变量赋值的。
使用global
语句可以清楚地表明变量是在外面的块定义的。结果:
可以使用同一个global
语句指定多个全局变量。例如global x, y, z
。
默认参数值
可以在函数定义的形参名后加上赋值运算符(=)和默认值,从而给形参指定默认参数值。默认参数值应该是不可变的。
如果我们不提供一个值,那么默认地,字符串将只被打印一遍。
关键参数
如果你的某个函数有许多参数,而你只想指定其中的一部分,那么你可以通过命名来为这些参数赋值——这被称作 关键参数 ——我们使用名字(关键字)而不是位置(我们前面所一直使用的方法)来给函数指定实参。
这样做有两个优势:
- 由于我们不必担心参数的顺序,使用函数变得更加简单了。
- 假设其他参数都有默认值,我们可以只给我们想要的那些参数赋值。
return语句
注意,没有返回值的return
语句等价于return None
。None
是Python中表示没有任何东西的特殊类型。例如,如果一个变量的值为None
,可以表示它没有值。除非你提供你自己的return
语句,每个函数都在结尾暗含有return None
语句。
通过运行print someFunc()
,你可以明白这一点,函数someFunc
没有使用return
语句,pass
语句在Python中表示一个空的语句块。
DocStrings
Python有一个很奇妙的特性,称为 文档字符串 ,它通常被简称为 docstrings。DocStrings是一个重要的工具,由于它帮助你的程序文档更加简单易懂,你应该尽量使用它。你甚至可以在程序运行的时候,从函数恢复文档字符串!
在函数的第一个逻辑行的字符串是这个函数的 文档字符串 。注意,DocStrings也适用于模块和类,我们会在后面相应的章节学习它们。
文档字符串的惯例是一个多行字符串,它的首行以大写字母开始,句号结尾。第二行是空行,从第三行开始是详细的描述。 强烈建议你在你的函数中使用文档字符串时遵循这个惯例。
你可以使用__doc__
(注意双下划线)调用printMax
函数的文档字符串属性(属于函数的名称)。
请记住Python把 每一样东西 都作为对象,包括这个函数。
我们会在后面的类一章学习更多关于对象的知识。
如果你已经在Python中使用过help()
,那么你已经看到过DocStings的使用了!它所做的只是抓取函数的__doc__
属性,然后整洁地展示给你。
你可以对上面这个函数尝试一下——加上语句help(printMax):
自动化工具也可以以同样的方式从你的程序中提取文档。因此,我 强烈建议 你对你所写的任何正式函数编写文档字符串。随你的Python发行版附带的pydoc命令,与help()
类似地使用DocStrings。