首页 > 编程问答 >是否可以通过 doctest 测试使用 get_type_hints 的函数?

是否可以通过 doctest 测试使用 get_type_hints 的函数?

时间:2024-07-23 14:36:33浏览次数:13  
标签:python doctest

我有一个使用 typing.get_type_hints 的函数。我想向其添加 文档测试 但是,看起来 get_type_hints 无法解析 doctest 中定义的类型。

这是一个简化的示例:

import typing

def f(clazz):
    """
    >>> class MyClass:
    ...   my_field: 'MyClass'
    >>> f(MyClass)
    """
    typing.get_type_hints(clazz)

当使用 python3 -m doctest test.py 运行它时,它会抛出 NameError: name 'MyClass' is not defined


你遇到的是doctest的一个常见问题:doctest无法解析自身示例中定义的类型提示。这是因为doctest在运行代码之前不会执行整个文件,所以它不知道“MyClass”是什么。

幸运的是,有几种方法可以解决这个问题:

1. 使用__post_init__方法 (对于dataclass):

如果 MyClass 是一个dataclass,你可以利用 __post_init__ 方法在类实例化之后调用 get_type_hints

from dataclasses import dataclass, fields
from typing import get_type_hints

@dataclass
class MyClass:
    my_field: 'MyClass'

    def __post_init__(self):
        """
        >>> MyClass(MyClass()).my_field.__name__
        'MyClass'
        """
        hints = get_type_hints(self.__class__)
        for field in fields(self):
            # 使用hints[field.name]进行类型检查等操作... 

2. 使用eval和locals():

你可以使用 eval 函数和 locals() 字典来动态地获取 MyClass 的定义。

import typing

def f(clazz):
    """
    >>> class MyClass:
    ...   my_field: 'MyClass'
    >>> f(MyClass)
    {'my_field': <class '__main__.MyClass'>}
    """
    return typing.get_type_hints(eval(clazz.__name__, globals(), locals()))

3. 使用单独的函数定义类型提示:

将类型提示与函数逻辑分离,可以避免doctest的解析问题。

import typing

def get_my_class_hints():
    """
    >>> get_my_class_hints()
    {'my_field': <class '__main__.MyClass'>}
    """
    class MyClass:
        my_field: 'MyClass'
    return typing.get_type_hints(MyClass)

def f(clazz):
    # 在这里使用get_type_hints(clazz)
    ... 

4. 使用unittest模块:

对于更复杂的测试场景,使用unittest模块可以提供更强大的功能和灵活性。

import unittest
import typing

class TestMyClass(unittest.TestCase):
    def test_my_class(self):
        class MyClass:
            my_field: 'MyClass'
        hints = typing.get_type_hints(MyClass)
        self.assertEqual(hints['my_field'], MyClass)

if __name__ == '__main__':
    unittest.main()

选择最适合你的方法取决于你的代码结构和测试需求。

标签:python,doctest
From: 55937472

相关文章

  • Python中如何实现字符串的查询和替换?
    在Python中,字符串的查询和替换是编程中常见的任务,它们可以通过Python的内置方法和库来高效实现。这些操作对于文本处理、数据清洗、日志分析等场景尤为重要。下面,我将详细阐述如何在Python中实现字符串的查询和替换,包括基础方法、高级技巧以及在实际应用中的注意事项。字符......
  • Python中的`range()`函数及其用法
    range()函数是Python中的一个内置函数,它用于生成一个数字序列。这个函数在循环结构中尤其有用,因为它允许我们迭代一系列的数字,而无需显式地创建这些数字的列表。range()函数通过指定起始值、结束值(不包括)和步长(可选)来工作,返回一个可迭代对象,通常用于for循环中。下面将......
  • python 的注释(例如数据类)可以扩展到它生成的代码中吗?
    能看出python的注释扩展成​​什么吗?例如,对于与数据类相关的错误,有时试图找出它实际生成的代码有点棘手。例如:@dataclass(order=True)classPerson:name:strage:int=0classPerson:def__init__(self,name:str,age=0):self.name=name......
  • Docker:无法在 docker 映像中使用 pythonnet 和 |无法创建默认的 .NET 运行时,该运行时
    我正在尝试使用clrfromPythonnet使用.DLL引用将一种文件类型转换为另一种文件类型。这就是我的代码的样子-importclrclr.AddReference(dll_path)importRxLibrary#ConverttoASCFormat-----------input_file=f"./{filename}.rxd"......
  • 在 Python 中以非常高的质量保存图像
    如何以非常高的质量保存Python绘图?也就是说,当我不断放大PDF文件中保存的对象时,为什么没有任何模糊?另外,什么是最好的模式将其保存在?png,eps?或者其他的?我不能pdf,因为有一个隐藏的数字会扰乱Latexmk编译。要以非常高的质量保存Py......
  • Python字符串:提取重复和随机合并的子字符串
    重复和合并字符串的示例:16.01068.0%08p%.a.p.a.要提取的所需子字符串:16.008%p.a.完整示例:CCoonnttiinnggeennttCCoouuppoonn16.01068.0%08p%.a.p(.Ma.o(nMtholyn)thly)所需子字符串:ContingentCoupon16.008%p.a.(Monthly)我的问题是当原始......
  • Python Pandas 从使用第 3 部分 API 自动生成的 Excel 文件中读取不一致的日期格式
    我正在使用PDF4meAPI将PDF发票转换为Excel文件。API可以正确读取日期。但是,当我打开Excel文件时,日期显示不一致:某些日期以正确的格式(dd/mm/yyyy)显示,而其他日期以错误的mm/dd/yyyy格式显示。当该月的某天小于或等于12时,似乎会出现这种不一致。......
  • python-input键盘输入
     str=input("请输入:")#用户键盘输入#str表示一个字符串类型的变量,input会将读取到的字符串放入str中print(str) aa='请输入:'str=input(aa)#用户键盘输入#str表示一个字符串类型的变量,input会将读取到的字符串放入str中print(str)      ......
  • Python从0到100(四十五):从字符串到前后端分离
    前言:零基础学Python:Python从0到100最新最全教程。想做这件事情很久了,这次我更新了自己所写过的所有博客,汇集成了Python从0到100,共一百节课,帮助大家一个月时间里从零基础到学习Python基础语法、Python爬虫、Web开发、计算机视觉、机器学习、神经网络以及人工智能相关知......
  • Python的运算符与条件表达式
    一、运算符Python数据是通过使用运算符来进行操作的,与数学运算符类似,主要运用于数字计算,比较大小和逻辑运算。Python中的运算符主要包括算术运算符、赋值运算符、比较运算符、逻辑运算符和位运算符。1.算术运算符算术运算符用在数字表达式中,作用和在数学中是一样的。Python......