- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Python3 类型标注支持操作由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
typing为Python的一个标注库,此默认支持PEP 484和PEP 526指定的类型提示。最基本的支持由Any、Union、Tuple、Callable、TypeVar和Generic类型组成.
有关完整的规范,请参阅PEP 484,有关任何类型提示的简单介绍,请参阅PEP 483.
举个栗子,函数接收并返回一个字符串,如下所示:
def func(name: str) -> str: return "Hello" + name
在函数func中,参数预期是str类型,并且返回str类型 。
typing模块的作用:
类型检查,防止运行时出现参数和返回值类型不符合 。
作为开发文档附加说明,方便使用者调用传入和返回类型 。
该模块加入之后并不会影响程序的运行,不会报正式的错误,只有提醒 。
类型别名通过将类型分配别名来进行定义,在这个例子中,Vector和List[str]可以视为可互换的同义词:
from typing import ListVector = List[str]def func(name: str) -> Vector: return [name]print(Vector, type(Vector)) # typing.List[str] <class 'typing.GenericMeta'>value = func("laozhang")print(value, type(value)) # ['laozhang'] <class 'list'>
使用NewType()辅助函数来创建不同的类型 。
from typing import NewTypeUserId = NewType("UserId", int)UserName = NewType("UserName", str)
静态类型检查器会将新类型视为它最原始类型的子类,这对于捕捉逻辑错误非常有用:
def from_int_to_str(user_id: UserId) -> str: return str(user_id) print(from_int_to_str(UserId(123))) # 123print(from_int_to_str(123)) # 123
你仍然可以对UserId类型的变量执行所有的int支持的操作,但结果将始终为int类型,如下:
value = UserId(123) + UserId(456)print(value) # 579print(type(value)) # <class 'int'>
值得注意的是,UserId = NewType("UserId", int),UserId是一个函数,该函数将会立即返回你传递给它的任何参数。这也意味着,无法创建UserId的子类型,因为它是运行时的标识函数,而不是实际类型,下面这种写法是错误的:
class MyUser(UserId): pass
但是,可以基于UserId创建NewType,如下:
ChildUserId = NewType("ChildUserId", UserId)
期望特定签名的回调函数可以将类型标注为Callable[[Arg1Type, Arg2Type], ReturnType]。例如:
from typing import Callabledef finder(on_success: Callable[[str, int], None]) -> None: pass def on_success(s: str, i: int) -> None: passfinder(on_success=on_success)
如果传递过去的回调函数中的参数或返回类型不匹配,PyCharm将会有警告提示 。
泛型可以使用typing模块中名为TypeVar的新工厂进行参数化,如下:
from typing import TypeVarT = TypeVar("T")def finder(s: T) -> T: return s
泛型类型可以有任意数量的类型变量,这样的话类型变量可能会收到限制:
from typing import TypeVarT = TypeVar("T", int, str)def finder(s: T) -> T: return s
这样的话,finder函数将只能接收int/str类型的参数,否则将会有警告提示 。
int,、float: 整形、浮点型 。
bool、str: 布尔型、字符串类型 。
List、Dict、Tuple、Set: 列表、字典、元组、集合 。
Iterable、Iterator: 可迭代类型、迭代器类型 。
Generator: 生成器类型 。
更多关于typing模块的使用:https://docs.python.org/zh-cn/3.7/library/typing.html 。
前几天有同学问到,这个写法是什么意思:
def add(x:int, y:int) -> int: return x + y
。
我们知道 Python 是一种动态语言,变量以及函数的参数是不区分类型。因此我们定义函数只需要这样写就可以了:
def add(x, y): return x + y
这样的好处是有极大的灵活性,但坏处就是对于别人代码,无法一眼判断出参数的类型,IDE 也无法给出正确的提示.
于是 Python 3 提供了一个新的特性:
函数注解 。
也就是文章开头的这个例子:
def add(x:int, y:int) -> int: return x + y
。
用 : 类型 的形式指定函数的参数类型,用 -> 类型 的形式指定函数的返回值类型.
然后特别要强调的是,Python 解释器并不会因为这些注解而提供额外的校验,没有任何的类型检查工作。也就是说,这些类型注解加不加,对你的代码来说没有任何影响:
输出:
但这么做的好处是:
让别的程序员看得更明白 。
让 IDE 了解类型,从而提供更准确的代码提示、补全和语法检查(包括类型检查,可以看到 str 和 float 类型的参数被高亮提示) 。
在函数的 __annotations__ 属性中会有你设定的注解:
输出:
在 Python 3.6 中,又引入了对变量类型进行注解的方法:
a: int = 123b: str = 'hello'
更进一步,如果你需要指明一个全部由整数组成的列表:
from typing import Listl: List[int] = [1, 2, 3]
但同样,这些仅仅是“注解”,不会对代码产生任何影响.
不过,你可以通过 mypy 库来检验最终代码是否符合注解.
安装 mypy:
pip install mypy
执行代码:
mypy test.py
如果类型都符合,则不会有任何输出,否则就会给出类似输出:
这些新特性也许你并不会在代码中使用,不过当你在别人的代码中看到时,请按照对方的约定进行赋值或调用.
当然,也不排除 Python 以后的版本把类型检查做到解释器里,谁知道呢.
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我.
原文链接:https://blog.csdn.net/y472360651/article/details/89137415 。
最后此篇关于Python3 类型标注支持操作的文章就讲到这里了,如果你想了解更多关于Python3 类型标注支持操作的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我正在尝试编写一个相当多态的库。我遇到了一种更容易表现出来却很难说出来的情况。它看起来有点像这样: {-# LANGUAGE ScopedTypeVariables #-} {-# LANGUAGE
谁能解释一下这个表达式是如何工作的? type = type || 'any'; 这是否意味着如果类型未定义则使用“任意”? 最佳答案 如果 type 为“falsy”(即 false,或 undef
我有一个界面,在IAnimal.fs中, namespace Kingdom type IAnimal = abstract member Eat : Food -> unit 以及另一个成功
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: What is the difference between (type)value and type(va
在 C# 中,default(Nullable) 之间有区别吗? (或 default(long?) )和 default(long) ? Long只是一个例子,它可以是任何其他struct类型。 最
假设我有一个案例类: case class Foo(num: Int, str: String, bool: Boolean) 现在我还有一个简单的包装器: sealed trait Wrapper[
这个问题在这里已经有了答案: Create C# delegate type with ref parameter at runtime (1 个回答) 关闭 2 年前。 为了即时创建委托(dele
我正在尝试获取图像的 dct。一开始我遇到了错误 The function/feature is not implemented (Odd-size DCT's are not implemented
我正在尝试使用 AFNetworking 的 AFPropertyListRequestOperation,但是当我尝试下载它时,出现错误 预期的内容类型{( “应用程序/x-plist” )}, 得
我在下面收到错误。我知道这段代码的意思,但我不知道界面应该是什么样子: Element implicitly has an 'any' type because index expression is
我尝试将 SignalType 从 ReactiveCocoa 扩展为自定义 ErrorType,代码如下所示 enum MyError: ErrorType { // .. cases }
我无法在任何其他问题中找到答案。假设我有一个抽象父类(super class) Abstract0,它有两个子类 Concrete1 和 Concrete1。我希望能够在 Abstract0 中定义类
我想知道为什么这个索引没有用在 RANGE 类型中,而是用在 INDEX 中: 索引: CREATE INDEX myindex ON orders(order_date); 查询: EXPLAIN
我正在使用 RxJava,现在我尝试通过提供 lambda 来订阅可观察对象: observableProvider.stringForKey(CURRENT_DELETED_ID) .sub
我已经尝试了几乎所有解决问题的方法,其中包括。为 提供类型使用app.use(express.static('public'))还有更多,但我似乎无法为此找到解决方案。 index.js : imp
以下哪个 CSS 选择器更快? input[type="submit"] { /* styles */ } 或 [type="submit"] { /* styles */ } 只是好
我不知道这个设置有什么问题,我在 IDEA 中获得了所有注释(@Controller、@Repository、@Service),它在行号左侧显示 bean,然后转到该 bean。 这是错误: 14-
我听从了建议 registering java function as a callback in C function并且可以使用“简单”类型(例如整数和字符串)进行回调,例如: jstring j
有一些 java 类,加载到 Oracle 数据库(版本 11g)和 pl/sql 函数包装器: create or replace function getDataFromJava( in_uLis
我已经从 David Walsh 的 css 动画回调中获取代码并将其修改为 TypeScript。但是,我收到一个错误,我不知道为什么: interface IBrowserPrefix { [
我是一名优秀的程序员,十分优秀!