Python 如何在处理列表和使用mypy时减少错误?

Python 如何在处理列表和使用mypy时减少错误?,python,mypy,Python,Mypy,我只是在工作中写这类东西,想知道是否有什么python方法可以减少Item.display()中与列表、迭代器和集合处理相关的额外内容 在Item.display()中是否有更类似python的方法来处理过滤和转换 有什么方法可以让我使用不同的类型使打字更容易吗 import unittest from dataclasses import dataclass, field from typing import Union, Tuple, List, Iterator @dataclass c

我只是在工作中写这类东西,想知道是否有什么python方法可以减少Item.display()中与列表、迭代器和集合处理相关的额外内容

在Item.display()中是否有更类似python的方法来处理过滤和转换

有什么方法可以让我使用不同的类型使打字更容易吗

import unittest
from dataclasses import dataclass, field
from typing import Union, Tuple, List, Iterator

@dataclass
class Category:
    id: str
    name: str = field(compare=False)
    canonical: Union['Category', None] = field(compare=False)

    def __hash__(self)->int:
        return self.id.__hash__()

    def unalias(self)->'Category':
        #There could be more tests here
        if self.canonical:
            return self.canonical
        else:
            return self

    def display_str(self)->str:
        if self.id and self.name:
            return f'{self.id} [{self.name}]'
        else:
            return self.id


@dataclass
class Item:
    id: str
    categories: List[Category]


    def display(self,primary:Category)-> List[str]:
        """Unalias, dedup and sort for display."""
        if not self.categories:
            return []

        def unalias(secs:Iterator[Category])->Iterator[Category]:
            return map(lambda c: c.unalias(), secs) 

        def de_prim(secs:Iterator[Category])->Iterator[Category]:
            return filter(lambda c: c.id != primary.id, secs)

        def to_display(secs:List[Category])->List[str] :  
            return list(map(lambda c: c.display_str(), secs) )

        de_primaried = set(de_prim(unalias(iter(self.categories))))
        if not de_primaried:
            return []    
        return sorted(to_display(de_primaried))


class DoiTest(unittest.TestCase):
    def test(self):
        primary = Category('shirt', 'Shirts', None)

        cats = [Category('snow','Snowflakes',
                         Category('frozen_water','Frozen Water',None) ),
                Category('t-shirt','Tee Shirts', primary),
                Category('cheese','Yummy Cheese',None)]
        item = Item( 'ItemX', cats)
        self.assertEqual( item.display(primary) , ['cheese [Yummy Cheese]', 'frozen_water [Frozen Water]'])

去掉mypy部分,看起来这就是你正在做的事情

def display(self, primary):
    return sorted(
        map(
            lambda c: c.display_str(), 
            set(
                filter(
                    lambda c: c.id != primary.id, 
                    map(
                        lambda c: c.unalias(), 
                        self.categories
                    )
                )
            )
        )
    )
除非有理由希望
categories
具有值
None
,否则我会将其初始化为空列表。由于
de_primaried
始终是映射的有效参数,即使它是空的,也不需要检查它并手动返回空列表


您可能想考虑在两个嵌套循环中建立返回值以便可读性(在我看来,一次性功能在一定程度上是不可行的,特别是考虑到额外类型的杂波)。另外,我完全有可能遗漏了什么,但是里面似乎有一些不必要的

list()
iter()
调用。

是的,这就是我想要做的。我想知道如何制作这些不必要的list()和iter()即使在mypy检查下,也不需要打电话。我不知道你在问什么;如果mypy出于某种原因使它们成为必要,那似乎很奇怪。不过我不熟悉那个图书馆,所以我不知道从哪里开始。谢谢你的帮助。