我有几个共享一些字段的namedtuple。我有一个接受这些元组的函数,并保证仅与共享字段进行交互。我想在mypy中对此类代码进行类型检查。
该代码的示例为:
from typing import NamedTuple
class Base(NamedTuple):
x: int
y: int
class BaseExtended(NamedTuple):
x: int
y: int
z: str
def DoSomething(tuple: Base):
return tuple.x + tuple.y
base = Base(3, 4)
base_extended = BaseExtended(5, 6, 'foo')
DoSomething(base)
DoSomething(base_extended)
当我在此代码上运行mypy时,我得到一个可预测的错误:
mypy_example.py:20:错误:“ DoSomething”的参数1具有不兼容的类型“ BaseExtended”;预期的“基础”
有没有办法构造我的代码并保持mypy类型检查?我无法从Base继承BaseExtended,因为NamedTuple继承实现中存在一个错误:
https://github.com/python/typing/issues/427
我也不想使用难看的“ Union [Base,BaseExtended]”,因为当我尝试对列表进行类型检查时这会中断,因为“ List [Union
[Base,BaseExtended]]”不等于“ List [BaseExtended] ]”,这是因为有关变体/协变类型的一些令人迷惑的魔术:
https://github.com/python/mypy/issues/3351
我应该放弃这个主意吗?
命名元组的构造方式typing.NamedTuple
尚无法从类继承。您必须编写自己的元类来扩展typing.NamedTupleMeta
该类,以使子类能够工作,即使如此,by生成的类collections.namedtuple()
也不能构建为extend
相反,您想使用新dataclasses
模块定义类并实现继承:
from dataclasses import dataclass
@dataclass(frozen=True)
class Base:
x: int
y: int
@dataclass(frozen=True)
class BaseExtended(Base):
z: str
该模块是Python 3.7中的新增功能,但您可以在Python 3.6上pip install dataclasses
向后移植。
上面定义了两个具有x
和y
属性的不可变类,BaseExtended
该类又添加了一个属性。BaseExtended
是的完整子类Base
,因此出于键入目的,适合该DoSomething()
功能的要求。
这些类不是全名的元组,因为它们没有长度或不支持索引,但是通过创建继承自的基类collections.abc.Sequence
并添加两个方法来按索引访问字段,可以轻松添加这些类。如果添加order=True
到@dataclass()
装饰器中,则您的实例将变得完全可订购,其元组的命名方式如下:
from collections.abc import Sequence
from dataclasses import dataclass, fields
class DataclassSequence(Sequence):
# make a dataclass tuple-like by accessing fields by index
def __getitem__(self, i):
return getattr(self, fields(self)[i].name)
def __len__(self):
return len(fields(self))
@dataclass(frozen=True, order=True)
class Base(DataclassSequence):
x: int
y: int
MyPy将很快dataclasses
明确支持;在版本0.600中,您仍然会遇到错误,因为它无法识别dataclasses
模块导入或__new__
生成了方法。
在Python
3.6和更低版本中,您还可以安装attrs
项目以实现相同的效果。上面的序列基类如下所示attrs
:
from collections.abc import Sequence
import attr
class AttrsSequence(Sequence):
# make a dataclass tuple-like by accessing fields by index
def __getitem__(self, i):
return getattr(self, attr.fields(type(self))[i].name)
def __len__(self):
return len(attr.fields(type(self)))
@attr.s(frozen=True, auto_attribs=True)
class Base(AttrsSequence):
x: int
y: int
dataclasses
直接基于attrs
,并attrs
提供更多功能;mypy完全支持使用生成的类attrs
。
我有几个共享一些字段。我有一个接受这些元组的函数,并保证只与共享字段交互。我想在mypy中键入检查此类代码。 代码的一个示例是: 当我对这段代码运行mypy时,我得到了一个可预见的错误: mypy_example.py:20:错误:“DoSomething”的参数1具有不兼容的类型“base extended”;预期的“基数” 有没有办法构造我的代码并保持我的py类型检查?我无法从< code>B
我如何确认通过props(例如)接收的反应元素在我的渲染方法中属于给定类型? 假设我有一个元素和一个元素。在的render方法中,我想查找传递的所有子项,并对s中的任何子项执行一些特殊的操作。 我确实找到了一个可行的实现,但只是在反复试验之后。请参阅下面的代码。(第15.4.2节) 我ist.jsx 名单我tem.jsx 所以,最后一个实现似乎可以工作,但是为什么第一个实现不能工作呢?我在reac
Blockly完全支持JS和Python之类的动态类型的模型,并且还包括对C / C ++之类的静态类型的模型的支持,但需要做一些额外的工作。 在这两种情况下,Blockly都可以防止构造一些非理性的组合。以下三个模块之间没有业务联系: Blockly的每种连接类型(值输入/输出,下一个/上一个语句)都可以用类型信息标记,以便显然无效的连接将拒绝连接。这为用户提供了即时反馈,并避免了许多简单的错误
本文向大家介绍python 检查文件mime类型的方法,包括了python 检查文件mime类型的方法的使用技巧和注意事项,需要的朋友参考一下 magic 模块可以检查文件的mime类型,而不是从后缀名来判断,例如判断文件是不是视频或图片类型如下: 以上这篇python 检查文件mime类型的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。
问题内容: 我正在学习使用装饰器模式,但遇到一个我认为很简单但似乎找不到答案的问题。假设我有一个抽象的饮料类。然后,让我们说一下扩展饮料的一些具体组成部分:美式咖啡,浓缩咖啡,拿铁咖啡等。还有扩展饮料的抽象调味品类。然后,调味品类有多个子类:牛奶,糖,大豆,鞭子。每个调味品子类都有一个cost和getdescription()方法,分别从Beverage和Condiments继承。我的问题是,如何