Python -类型提示 Type Hints
为什么会有类型提示
- Python是一种动态类型语言,这意味着我们在编写代码的时候更为自由,运行时不需要指定变量类型
- 但是与此同时 IDE 无法像静态类型语言那样分析代码,及时给我们相应的提示,比如字符串的 split 方法
def split_str(s):
strs = s.split(",")
由于不知道参数 s 是什么类型,所以当你敲 s. 的时候不会出现 split 的语法提示
解决上述问题,类型提示
Python 3.6 新增了两个特性 PEP 484 和 PEP 526
帮助 IDE 为我们提供更智能的提示
这些新特性不会影响语言本身,只是增加一点提示
类型提示分类
主要分两个
- 变量提示:PEP 526 特性加的
- 函数参数提示:PEP 484 特性加的
变量类型提示
没有使用类型提示
想说明变量的数据类型只能通过注释
# 'primes' is a list of integers
primes = [] # type: List[int] # 'captain' is a string (Note: initial value is a problem)
captain = ... # type: str class Starship:
# 'stats' is a class variable
stats = {} # type: Dict[str, int]
使用了类型提示
from typing import List, ClassVar, Dict # int 变量,默认值为 0
num: int = 0 # bool 变量,默认值为 True
bool_var: bool = True # 字典变量,默认为空
dict_var: Dict = {} # 列表变量,且列表元素为 int
primes: List[int] = [] class Starship:
# 类变量,字典类型,键-字符串,值-整型
stats: ClassVar[Dict[str, int]] = {} # 实例变量,标注了是一个整型
num: int
这里会用到 typing 模块,后面会再展开详解
假设变量标注了类型,传错了会报错吗?
from typing import List # int 变量,默认值为 0
num: int = 0 # bool 变量,默认值为 True
bool_var: bool = True # 字典变量,默认为空
dict_var: Dict = {} # 列表变量,且列表元素为 int
primes: List[int] = [] num = "123"
bool_var = 123
dict_var = []
primes = ["1", "2"] print(num, bool_var, dict_var, primes) # 输出结果
123 123 [] ['1', '2']
它并不会报错,但是会有 warning,是 IDE 的智能语法提示

所以,这个类型提示更像是一个规范约束,并不是一个语法限制
变量类型提示-元组打包
# 正常的元组打包
a = 1, 2, 3 # 加上类型提示的元组打包
t: Tuple[int, ...] = (1, 2, 3)
print(t) t = 1, 2, 3
print(t) # py3.8+ 才有的写法
t: Tuple[int, ...] = 1, 2, 3
print(t) t = 1, 2, 3
print(t) # 输出结果
(1, 2, 3)
(1, 2, 3)
(1, 2, 3)
(1, 2, 3)
为什么要加 ...

不加的话,元组打包的时候,会有一个 warning 提示
变量类型提示-元组解包
# 正常元组解包
message = (1, 2, 3)
a, b, c = message
print(a, b, c) # 输出 1 2 3 # 加上类型提示的元组解包
header: str
kind: int
body: Optional[List[str]] # 不会 warning 的栗子
header, kind, body = ("str", 123, ["1", "2", "3"]) # 会提示 warning 的栗子
header, kind, body = (123, 123, ["1", "2", "3"])
Optional 会在后面讲 typing 的时候详解
在类里面使用
class BasicStarship:
captain: str = 'Picard' # 实例变量,有默认值
damage: int # 实例变量,没有默认值
stats: ClassVar[Dict[str, int]] = {} # 类变量,有默认值
ClassVar
- 是 typing 模块的一个特殊类
- 它向静态类型检查器指示不应在类实例上设置此变量
函数参数类型提示
不仅提供了函数参数列表的类型提示,也提供了函数返回的类型提示
栗子一
# 参数 name 类型提示 str,而函数返回值类型提示也是 str
def greeting(name: str) -> str:
return 'Hello ' + name
栗子二
def greeting(name: str, obj: Dict[str, List[int]]) -> None:
print(name, obj)
Python -类型提示 Type Hints的更多相关文章
- Python 类型提示简介
Python 3.6+ 版本加入了对"类型提示"的支持. 这些"类型提示"是一种新的语法(在 Python 3.6 版本加入)用来声明一个变量的类型. 通过声明 ...
- 全面理解Python中的类型提示(Type Hints)
众所周知,Python 是动态类型语言,运行时不需要指定变量类型.这一点是不会改变的,但是2015年9月创始人 Guido van Rossum 在 Python 3.5 引入了一个类型系统,允许开发 ...
- Python - typing 模块 —— 常用类型提示
前言 typing 是在 python 3.5 才有的模块 前置学习 Python 类型提示:https://www.cnblogs.com/poloyy/p/15145380.html 常用类型提示 ...
- Python Type Hints(类型提示)
在做自动化测试的时候,改进测试框架,类型提示会让你写代码时更加流程,当你在一个模块定义了类型,而其他模块没有提示的时候,是相当不方便.
- Python type hints 之 Optional,Union
1,前言 type hint 在pep484加入,我个人觉得这种类似于类型约束的(机制)有点违背了python简单.简洁的初衷,在慢慢向c# java 这种强类型语言看齐的节奏. 不过好在不强制使用, ...
- python进阶(21)typing模块--类型提示支持
typing介绍 Python是一门弱类型的语言,很多时候我们可能不清楚函数参数的类型或者返回值的类型,这样会导致我们在写完代码一段时间后回过头再看代码,忘记了自己写的函数需要传什么类型的参数,返 ...
- Python中使用Type hinting 和 annotations
Type hints最大的好处就是易于代码维护.当新成员加入,想要贡献代码时,能减少很多时间. 也方便我们在调用汉书时提供了错误的类型传递导致运行时错误的检测. 第一个类型注解示例 我们使用一个简单例 ...
- python类型检测最终指南--Typing模块的使用
正文共:30429 字 预计阅读时间:76分钟 原文链接:https://realpython.com/python-type-checking/ 作者:Geir Arne Hjelle 译者:陈祥安 ...
- 介绍几款 Python 类型检查工具
近日,微软在 Github 上开源了一个 Python 静态类型检查工具:pyright ,引起了社区内的多方关注. 微软在开源项目上的参与力度是越来越大了,不说收购 Github 这种大的战略野心, ...
随机推荐
- AcWing 1275. 最大数
#include<bits/stdc++.h> #define N 1000100 using namespace std; struct node { int l,r; int data ...
- 【IllegalArgumentException】: object is not an instance of declaring class
java.lang.IllegalArgumentException: object is not an instance of declaring class 日前在调试动态代理的例子中,出现以上报 ...
- python二进制读写及特殊码同步
python对二进制文件的操作需要使用bytes类,直接写入整数是不行的,如果试图使用f.write(123)向文件中以二进制写入123,结果提示参数不是bytes类型. import os impo ...
- Jsp自定义标签,配置tld文件
Program:Jsp自定义标签,.tld文件的配置 1 <?xml version="1.0" encoding="UTF-8" ?> 2 3 & ...
- WPF技巧:通过代码片段管理器编写自己常用的代码模板提示效率
在写自定义控件的时候,有一部分功能是当内部的值发生变化时,需要通知控件的使用者,而当我在写依赖项属性的时候,我可以通过popdp对应的代码模板来完成对应的代码,但是当我来写属性更改回调的时候,却发现没 ...
- 「CF526F」 Pudding Monsters
CF526F Pudding Monsters 传送门 模型转换:对于一个 \(n\times n\) 的棋盘,若每行每列仅有一个棋子,令 \(a_x=y\),则 \(a\) 为一个排列. 转换成排列 ...
- Django基础-03篇 操作Django自带的admin后台
1.使用model.py来定义表结构,使用命令同步到数据库 python manage.py makemigrations #生成表结构(py) python manage.py makemigrat ...
- C语言:函数
1. int scanf ( char * format [ ,argument, ... ]); 返回被赋值的参数的个数
- adb 记录ADB执行记录
自动化测试需要获得当前的activity,来判断处于的页面是否正确: hierarchy view经常连不上真机,无法获得activity,所以直接用 adb命令来查看当前运行的 activity就可 ...
- [善用佳软]Chrome插件之彩云小译
最近公众号新推出个栏目[善用佳软],旨在和大家分享各种小插件和制作开源小软件. 最近在浏览外网时,发现一个贼好用的翻译神器---[彩云小译],在网页端就可以快速的对照翻译出来,经过试用发现无论是速度还 ...