- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试使用 mypy
在一些使用 LXML 的代码中进行类型检查解析 XML 的库。
在我使用 etree.XPath
的每一行中,我都会从 mypy
中得到一个虚假错误。例如,下面的简单脚本
from lxml import etree
NameXPath = etree.XPath("Name/text()")
产生错误
test.py:3: error: "module" has no attribute "XPath"
但脚本运行良好,我的 XPath
在运行时也能正常工作。
我还在导入时尝试了 #type:ignore
,我认为这可能会告诉 mypy
不要对该库进行类型检查,但这并没有抑制错误。
from lxml import etree # type:ignore
NameXPath = etree.XPath("Name/text()")
通过将对 etree.XPath
的调用移动到一个没有任何类型注释的单独函数中,我确实在抑制一些错误方面取得了一些成功,但这似乎是一种 hack 和强制我以笨拙的方式安排我的代码。
我想知道是否有办法完全抑制这些虚假错误,或者可能暗示 etree.XPath
函数确实存在,因为它似乎无法识别自己出来。
明确地说,我实际上并不关心 mypy
是否知道来自 lxml
库的结构的正确类型。我更关心将类型信息放在我自己的类中,我将解析的信息插入其中,所以我想要使用 etree.XPath
进行查询的类型检查函数,找到数据,然后将它们推送到我的脚本中定义的类型注释类中。
mypy
似乎对 etree
中的其他函数没有困难,例如我对 etree.parse
的调用没问题/p>
我目前正在使用 mypy
0.4.4
最佳答案
看起来这是 typeshed 中的错误,社区为 stdlib 和各种第三方库提供的类型注释集合。
特别是,它看起来好像 stubs for lxml完全缺少 XPath 的定义。这可能是一个疏忽——我会尝试在问题跟踪器上提交错误或尝试提交包含修复的拉取请求。
一旦修复此问题,并且 mypy 与最新版本的 typeshed 重新同步,您将需要从 git repo 安装 mypy目前(至少,直到 mypy 0.4.5 在 10 月的某个时候发布)。
同时,您可以通过以下方式解决此问题:
from lxml.etree import XPath # type: ignore
NameXPath = XPath("Name/text()")
# mypy considers NameXPath to have a type of Any
...或者,如果您希望对 XPath 进行更具体的定义,请执行以下操作:
import typing
if typing.TYPE_CHECKING:
# typing.TYPE_CHECKING is always False at runtime, so this
# branch is parsed by typecheckers only
class XPath:
# Provide a method header stubs with signatures to fool
# mypy into understanding what the interface for XPath is
else:
# Actually executed at runtime
from lxml.etree import XPath # type: ignore
NameXPath = XPath("Name/text()")
关于python - mypy 虚假错误 : "module" has no attribute "XPath" with etree,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39382937/
关于 this页面,我看到以下代码: if ((attributes & FileAttributes.Hidden) == FileAttributes.Hidden) 但我不明白为什么会变成这样。
函数pthread_mutex_init允许您指定指向属性的指针。但是我还没有找到关于pthread属性是什么的很好的解释。我一直只是提供NULL。这个论点有用吗? 该文档,对于那些忘记它的人: PT
我们有一个 xml 节点“item”,其属性为“style”,即“Header1”。但是,这种风格可以改变。我们有一个名为 Header1 的属性集,它定义了它在 PDF 中的外观,通过 xsl:fo
我的任务是在用户点击它时从输入框中删除占位符并使标签可见。如果用户未在其中再次填写任何内容,请放回占位符并使标签不可见。 我可以隐藏它但不能重新分配它。我试过 element.setAttribute
我从文章中编写代码,并且有: public IActionResult Create([Bind(Include="Imie,Nazwisko,Stanowisko,Wiek")] Pracownik
你能给我解释一下以下属性吗? 1) [MonoTouch.Foundation.Register("SomeClass")] 这个属性是否只用于向IB注册类?以编程方式扩展 iOS 类时是否必须使用此
我正在编写一个 C++ 程序,在调试时我在执行以下函数: int CClass::do_something() { ... // I've put a breakpoint here } 我的 C
我已经在 polymer 0.5 中构建了我的应用程序。 现在我已经将它更新到 polymer 1.0。 对于响应式布局,我使用了一个布局属性,它使用 Polymer 0.5 中布局属性的自定义逻辑。
我是使用 Jade 的新手——到目前为止它很棒。 但是我需要发生的一件事是具有“itemscope”属性的元素: 我的 Jade 符是: header(itemscope, itemtype='ht
我正在研究一个厨师实现,有时在过去的地方使用了 attribute.set,attribute.default 会这样做。为了解决这个问题,我对 Chef 属性优先范式非常熟悉。我知道“正常”属性(使
我经常看到html data-attribute (s) 将特定值/参数添加到 html 元素,例如使用它们将按钮“链接”到要打开的模式对话框等的 Bootstrap。 现在,我看到一个几乎著名的
假设如下: def create_new_salt self.salt = self.object_id.to_s + rand.to_s end 为什么使用“ self ”更好。而不是实例变量“
根据我的理解,Backbone.js 模型的属性应该通过以下方式声明为有点私有(private)的成员变量 this.set({ attributeName: attributeValue }) //
我有一个看起来像下面的XML文档: ... ... ... ...
我正在实现一个 JSF 组件,需要有条件地添加一些属性。这个问题类似于之前的 JSF: p:dataTable with f:attribute results in "argument type m
我正在尝试将应用程序发布到 Android 电子市场,但出现以下错误: W/ResourceType(16964): No known package when getting value for r
抱歉这么具体的应用程序,但我注意到另一篇关于 Maya 开发的回答很好的帖子。 我刚刚为 Maya 编写了一个插件节点。它只是根据湍流函数杀死一堆粒子。湍流由许多可在属性编辑器中调整的属性驱动。 在属
我在 html 元素中的数据属性为 Update .它具有数据属性的 bool 值。 跟下面的元素Update有什么区别吗?因为数据属性用双引号引起来。 html是否支持 bool 值? 最佳答案 b
我正在尝试为企业库 5.0 的异常处理 block 创建自定义异常处理程序。据我了解,我需要使用属性开始上课“[ConfigurationElementType(typeof(CustomHandle
我找不到这两个选择器之间的区别。两者似乎都做同样的事情,即根据包含给定字符串的特定属性值选择标签。 对于 [attribute~=value] :http://www.w3schools.com/cs
我是一名优秀的程序员,十分优秀!