您的位置:首页 > 编程语言 > Python开发

Python学习手记 pt4 函数

2010-08-12 15:53 393 查看
函数通过def关键字定义。def关键字后跟一个函数的标识符名称,然后跟一对圆括号。圆括号之中可以包括一些变量名,该行以冒号结尾。接下来是一块语句,它们是函数体。下面这个例子将说明这事实上是十分简单的:


无参数:

defsayHello():
print'HelloWorld!'#blockbelongingtothefunction
sayHello()#callthefunction

带参数:

defsayHello(s):
prints#blockbelongingtothefunction
sayHello(raw_input('typesomewords'))#callthefunction


记住用def来定义模块.之后要紧跟:


global语句
如果你想要为一个定义在函数外的变量赋值,那么你就得告诉Python这个变量名不是局部的,而是全局的。我们使用global语句完成这一功能。没有global语句,是不可能为定义在函数外的变量赋值的。你可以使用定义在函数外的变量的值(假设在函数内没有同名的变量)。然而,我并不鼓励你
这样做,并且你应该尽量避免这样做,因为这使得程序的读者会不清楚这个变量是在哪里定义的。使用global语句可以清楚地表明变量是在外面的块定义的。


#!/usr/bin/python
#Filename:func_global.py
deffunc():
globalx
print'xis',x
x=2
print'Changedlocalxto',x
x=50
func()
print'Valueofxis',x

global语句被用来声明x是全局的——因此,当我们在函数内把值赋给x的时候,这个变化也反映在我们在主块中使用x的值的时候。你可以使用同一个global语句指定多个全局变量。例如globalx,y,z。



默认参数值
对于一些函数,你可能希望它的一些参数是可选的,如果用户不想要为这些参数提供值的话,这些参数就使用默认值。这个功能借助于默认参数值完成。你可以在函数定义的形参名后加上赋值运算符(=)和默认值,从而给形参指定默认参数值。注意,默认参数值应该是一个参数。更加准确的说,默认参数值应该是不可变的,从现在开始,请记住这一点。
使用默认参数值
例7.5使用默认参数值


#!/usr/bin/python
#Filename:func_default.py
defsay(message,times=1):
printmessage*times//这里*times表示连续输出times次.
say('Hello')
say('World',5)



关键参数
如果你的某个函数有许多参数,而你只想指定其中的一部分,那么你可以通过命名来为这些参数赋值——这被称作关键参数——我们使用名字(关键字)而不是位置(我们前面所一直使用的方法)来给函数指定实参。
这样做有两个优势——一,由于我们不必担心参数的顺序,使用函数变得更加简单了。二、假设其他参数都有默认值,我们可以只给我们想要的那些参数赋值。
使用关键参数


例7.6使用关键参数
#!/usr/bin/python
#Filename:func_key.py
deffunc(a,b=5,c=10):
print'ais',a,'andbis',b,'andcis',c
func(3,7)
func(25,c=24)
func(c=50,a=100)
输出
$pythonfunc_key.py
ais3andbis7andcis10//c是默认值
ais25andbis5andcis24//b是默认值
ais100andbis5andcis50//类似c//



return语句:返回.如果没有返回值的return语句等价于returnNone。None是Python中表示没有任何东西的特殊类型。例如,如果一个变量的值为None,可以表示它没有值。除非你提供你自己的return语句,每个函数都在结尾暗含有returnNone语句。通过运行printsomeFunction(),你可以明白这一点,函数someFunction没有使用return语句,如同:
defsomeFunction():
pass//一般定义好后,先随后再写.用这个
pass语句在Python中表示一个空的语句块。

DocStrings

Python有一个很奇妙的特性,称为文档字符串,它通常被简称为docstrings。DocStrings是一个重要的工具,由于它帮助你的程序文档更加简单易懂,你应该尽量使用它。你甚至可以在程序运行的时候,从函数恢复文档字符串!

使用DocStrings


#!/usr/bin/python
#Filename:func_doc.py
defprintMax(x,y):
'''Printsthemaximumoftwonumbers.

Thetwovaluesmustbeintegers.'''
x=int(x)#converttointegers,ifpossible
y=int(y)
ifx>y:
printx,'ismaximum'
else:
printy,'ismaximum'
printMax(3,5)
printprintMax.__doc__



输出
$pythonfunc_doc.py
5ismaximum
Printsthemaximumoftwonumbers.
Thetwovaluesmustbeintegers.

在函数的第一个逻辑行的字符串是这个函数的文档字符串。注意,DocStrings也适用于模块和类。文档字符串的惯例是一个多行字符串,它的首行以大写字母开始,句号结尾。第二行是空行,从第三行开始是详细的描述。强烈建议你在你的函数中使用文档字符串时遵循这个惯例。
你可以使用__doc__(注意双下划线)调用printMax函数的文档字符串属性(属于函数的名称)。请记住Python把每一样东西都作为对象,包括这个函数。它所做的只是抓取函数的__doc__属性,然后整洁地展示给你。你可以对上面这个函数尝试一下——只是在你的程序中包括help(printMax)。记住按q退出help。自动化工具也可以以同样的方式从你的程序中提取文档。因此,我强烈建议你对你所写的任何正式函数编写文档字符串。随你的Python发行版附带的pydoc命令,与help()类似地使用DocStrings。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐
章节导航