Функция по атрибуту init

Мне нужно вызвать функцию, прежде чем инициализировать атрибут, предпочтительно используя класс данных python3.7, также может быть назван кортежем.

Этот код делает что-то похожее, и имя атрибута просто набирается один раз, но это очень запутанно, и я не знаю, как поддерживать значения по умолчанию. Я уверен, что есть лучший и более питонский способ сделать это.

from collections import namedtuple

person = {
    'name': (lambda value: value.upper()),
    'age': (lambda value: value*2),
}



class Person(namedtuple("Person", person.keys())):
    def __new__(cls, **kwargs):
        return super().__new__(cls, **{k:person[k](v) for k, v in kwargs.items() if v is not None and k in person})


l = Person(**{'name': 'gesiel', 'age': 34})
print(l)

1 ответ

Решение

Самый простой способ сделать это - просто иметь обычный класс данных с вспомогательной функцией, которая выполняет преобразования перед построением Person объект.

@dataclass
class Person:
    age: int
    name: str

def make_person(age, name):
    return Person(age*2, name.upper())

person = make_person(100, 'patrick')
print(person.age, person.name)
# 200 PATRICK

Другой вариант - использовать обработку после инициализации для изменения значений.

@dataclass
class Person:
    age: int
    name: str
    def __post_init__(self):
        self.age  = self.age * 2
        self.name = self.name.upper()

person = Person(100, 'patrick')
print(person.age, person.name)
# 200 PATRICK
Другие вопросы по тегам