python中函数的写法 python中的函数怎么用

python主函数怎么写一般来说,Python程序员可能是这样写main()函数的python中函数的写法:
"""Module docstring.
This serves as a long usage message.
"""import sysimport getoptdef main():
# parse command line options
try:
opts, args = getopt.getopt(sys.argv[1:], "h", ["help"])except getopt.error, msg:print msgprint "for help use --help"
sys.exit(2)# process options
for o, a in opts:if o in ("-h", "--help"):print __doc__
sys.exit(0)# process arguments
for arg in args:
process(arg) # process() is defined elsewhereif __name__ == "__main__":
main()1234567891011121314151617181920212223242526
Guido也承认之前自己写的main()函数也是类似的结构 , 但是这样写的灵活性还不够高,尤其是需要解析复杂的命令行选项时 。为此,他向大家提出python中函数的写法了几点建议 。
添加可选的 argv 参数
首先 , 修改main()函数,使其接受一个可选参数 argv,支持在交互式shell中调用该函数python中函数的写法:
def main(argv=None):
if argv is None:
argv = sys.argv# etc., replacing sys.argv with argv in the getopt() call.1234
这样做 , 我们就可以动态地提供 argv 的值,这比下面这样写更加的灵活:
def main(argv=sys.argv):
# etc.12
这是因为在调用函数时,sys.argv 的值可能会发生变化;可选参数的默认值都是在定义main()函数时,就已经计算好的 。
但是现在sys.exit()函数调用会产生问题:当main()函数调用sys.exit()时,交互式解释器就会推出python中函数的写法!解决办法是让main()函数的返回值指示退出状态(exit status) 。因此,最后面的那行代码就变成了这样:
if __name__ == "__main__":
sys.exit(main())12
并且,main()函数中的sys.exit(n)调用全部变成return n 。
定义一个Usage()异常
另一个改进之处 , 就是定义一个Usage()异常 , 可以在main()函数最后的except子句捕捉该异常:
import sysimport getoptclass Usage(Exception):
def __init__(self, msg):
self.msg = msgdef main(argv=None):
if argv is None:
argv = sys.argvtry:try:
opts, args = getopt.getopt(argv[1:], "h", ["help"])except getopt.error, msg:raise Usage(msg)# more code, unchanged
except Usage, err:print sys.stderr, err.msgprint sys.stderr, "for help use --help"
return 2if __name__ == "__main__":
sys.exit(main())123456789101112131415161718192021222324
这样main()函数就只有一个退出点(exit)了,这比之前两个退出点的做法要好 。而且 , 参数解析重构起来也更容易:在辅助函数中引发Usage的问题不大,但是使用return 2却要求仔细处理返回值传递的问题 。
Python中定义函数的使用方法?4.6. 定义函数
我们可以创建一个用来生成指定边界的斐波那契数列的函数:
def fib(n):# write Fibonacci series up to n
..."""Print a Fibonacci series up to n."""
...a, b = 0, 1
...while an:
...print(a, end=' ')
...a, b = b, a b
...print()
...
# Now call the function we just defined:
... fib(2000)
0 1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 987 1597
关键字 def 引入了一个函数 定义 。在其后必须跟有函数名和包括形式参数的圆括号 。函数体语句从下一行开始 , 必须是缩进的 。
函数体的第一行语句可以是可选的字符串文本,这个字符串是函数的文档字符串,或者称为 docstring 。(更多关于 docstrings 的信息请参考 文档字符串) 有些工具通过 docstrings 自动生成在线的或可打印的文档,或者让用户通过代码交互浏览;在你的代码中包含 docstrings 是一个好的实践,让它成为习惯吧 。
函数 调用 会为函数局部变量生成一个新的符号表 。确切的说 , 所有函数中的变量赋值都是将值存储在局部符号表 。变量引用首先在局部符号表中查找,然后是包含函数的局部符号表,然后是全局符号表,最后是内置名字表 。因此 , 全局变量不能在函数中直接赋值(除非用 global 语句命名),尽管他们可以被引用 。
函数引用的实际参数在函数调用时引入局部符号表 , 因此,实参总是 传值调用 (这里的 值 总是一个对象 引用 ,而不是该对象的值) 。[1] 一个函数被另一个函数调用时,一个新的局部符号表在调用过程中被创建 。
一个函数定义会在当前符号表内引入函数名 。函数名指代的值(即函数体)有一个被 Python 解释器认定为 用户自定义函数 的类型 。这个值可以赋予其他的名字(即变量名),然后它也可以被当作函数使用 。这可以作为通用的重命名机制:
fib
f = fib
f(100)
0 1 1 2 3 5 8 13 21 34 55 89
如果你使用过其他语言 , 你可能会反对说:fib 不是一个函数,而是一个方法,因为它并不返回任何值 。事实上,没有 return 语句的函数确实会返回一个值,虽然是一个相当令人厌烦的值(指 None ) 。这个值被称为 None (这是一个内建名称) 。如果 None 值是唯一被书写的值,那么在写的时候通常会被解释器忽略(即不输出任何内容) 。如果你确实想看到这个值的输出内容 , 请使用 print() 函数:
python中print函数的用法print()函数用于打印输出,是python中最常见的一个内置函数 。
【python中函数的写法 python中的函数怎么用】print()函数的语法如下:
print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False) 。
将"objects"打印输出至"file参数"指定的文本流 , 以"sep参数"分隔开并在末尾加上"end参数" 。"sep"、"end "、"file"和"flush"必须以关键字参数的形式给出 。flush关键字参数是在phthon3.3版后增加的 。
所有非关键字参数都会被转换为字符串,就像是执行了str()一样 , 并会被写入到流,以“sep参数“且在末尾加上“end参数“ 。“sep参数“和“end参数“都必须为字符串;它们也可以为“None“,这意味着使用默认值 。如果没有给出“objects参数“ , 则print()将只写入“end参数“ 。
ython print()函数:
print()方法用于打印输出,最常见的一个函数 。
在Python3.3版增加了flush关键字参数 。
print在Python3.x是一个函数,但在Python2.x版本不是一个函数,只是一个关键字 。
关于python中函数的写法和python中的函数怎么用的介绍到此就结束了 , 不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

    推荐阅读