参考官方文档 typing 是 3.5 版本的新功能, Python 运行时不强制执行函数和变量类型注解, 但我们写完代码一段时间后再回来看我们的代码, 可能就忘记了自己所写的函数需要传什么参数、返回什么类型的结果, 又得去阅读代码, 这样就大大降低了开发的效率, 而 typing 模块的数显很好的解决了这个问题
def add(name:str,age:int=22)->str:
return f"名字:{name} 年龄:{age}"
print(add("派大星")) # 名字:派大星 年龄:22
from typing import List,Tuple,Dict
def add(name:str,age:int,height:float,sex:bool=True)->Tuple[List,Tuple,Dict,bool]:
list1 = [name,age,height,sex]
tuple1 = [1,2,3,4]
dic1 = {"name":name,"age":age}
return list1,tuple1,dic1,sex
print(add("派大星",22,1.72,True))
# (['派大星', 22, 1.72, True], [1, 2, 3, 4], {'name': '派大星', 'age': 22}, True)
__annotation__
函数的注解信息都保存在 __annotation__
属性中, 它是一个字典, 包括返回值类型声明
def bar(name:str,age:int)->str:
return f"名字:{name} 年龄:{age}"
#Python小白学习交流群:725638078
print(bar.__annotations__)
# {'name': , 'age': , 'return': }
把类型赋给别名,就可以定义类型别名, 类型别名适用于简化复杂的类型签名
from typing import List
Li = List[str] # 这里 Li 和 List[str] 的意义是相同的
def add(name:str,age:int)->Li:
return [name]
print(add("shawn",22)) # ['shawn'] (列表类型只支持一个元素, 不然报错)
from typing import List,Tuple,Dict
People = Tuple[str,int]
Other = Dict[str,int]
Info = Tuple[People,Other]
def add(name:str,info:Info)->None: # 这种写法等同于下面的写法
...
def add2(name:str,info:Tuple[Tuple[str,int],Dict[str,int]])->None:
...