python系列教程206——函数注释

Posted 人工智能AI技术

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python系列教程206——函数注释相关的知识,希望对你有一定的参考价值。

朋友们,如需转载请标明出处:https://blog.csdn.net/jiangjunshow

声明:在人工智能技术教学期间,不少学生向我提一些python相关的问题,所以为了让同学们掌握更多扩展知识更好地理解AI技术,我让助理负责分享这套python系列教程,希望能帮到大家!由于这套python教程不是由我所写,所以不如我的AI技术教学风趣幽默,学起来比较枯燥;但它的知识点还是讲到位的了,也值得阅读!想要学习AI技术的同学可以点击跳转到我的教学网站。PS:看不懂本篇文章的同学请先看前面的文章,循序渐进每天学一点就不会觉得难了!

在Python 3.0中,可以给函数对象附加注解信息。这些信息会附加到函数对象的__annotations__属性。

如下是一个不带注解的函数,它编写为带有3个参数并且返回一个结果:

>>>def func(a,b,c):

...    return a + b + c

...

>>>func(1,2,3)

6

从语法上讲,函数注解编写在def头部行。对于参数,它们出现在紧随参数名之后的冒号之后;对于返回值,它们编写于紧跟在参数列表之后的一个->之后。例如,这段代码,注解了前面函数的3个参数及其返回值:

>>>def func(a: 'spam',b: (1,10),c: float) -> int:

...    return a + b + c

...

>>>func(1,2,3)

6

Python将注解信息收集到字典中并且将它们附加给函数对象自身。参数名变成键,如果编写了返回值注解的话,它存储在键“return”下:

>>>func.__annotations__

'a': 'spam','c': <class 'float'>,'b': (1,10),'return': <class 'int'>

下面的例子只是注解了3个参数中的两个:

>>>def func(a: 'spam',b,c: 99):

...    return a + b + c

...

>>>func(1,2,3)

6

>>>func.__annotations__

'a': 'spam','c': 99




>>>for arg in func.__annotations__:

... print(arg,'=>',func.__annotations__[arg])

...

a => spam

c => 99

如果编写了注解的话,仍然可以对参数使用默认值——注解出现在默认值之前。例如,下面的a: ‘spam’ = 4意味着参数a的默认值是4,并且用字符串’spam’注解它:

>>>def func(a: 'spam' = 4,b: (1,10) = 5,c: float = 6) -> int:

...    return a + b + c

...

>>>func(1,2,3)

6

>>>func()                # 4 + 5 + 6 (all defaults)

15

>>>func(1,c=10)         # 1 + 5 + 10 (keywords work normally)

16

>>>func.__annotations__

'a': 'spam','c': <class 'float'>,'b': (1,10),'return': <class 'int'>

以上是关于python系列教程206——函数注释的主要内容,如果未能解决你的问题,请参考以下文章

Python小白入门系列教程:注释变量输出运算符,看过的都收藏了

Python学习教程:如何用python统计代码行数

Python入门教程第27篇 函数之文档注释

Python入门系列教程函数

python系列教程151——range函数

python系列教程201——递归函数