Python自己实现namedtuple

用 type() 或者 types.new_class()

import operator
import types


def namedtuple(cls_name, field_names):
    attr_dict = {filed_name: property(operator.itemgetter(idx)) for idx, filed_name in enumerate(field_names)}

    def __new__(cls, *args):
        if len(args) != len(field_names):
            raise TypeError("Expected {} arguments".format(len(field_names)))
        return tuple.__new__(cls, args)

    attr_dict["__new__"] = __new__

    # return type(cls_name, (tuple,), attr_dict)
    return types.new_class(cls_name, (tuple,), {}, lambda ns: ns.update(attr_dict))


if __name__ == "__main__":
    Point = namedtuple("Point", ["x", "y"])
    p = Point(1, 2)
    print(p.x, p.y)

元类

import operator


class NamedTuple(type):

    def __init__(cls, *args, **kwargs):
        super().__init__(*args, **kwargs)
        for idx, field_name in enumerate(cls._field_names):
            setattr(cls, field_name, property(operator.itemgetter(idx)))


class NamedTupleBase(tuple, metaclass=NamedTuple):
    _field_names = ()

    def __new__(cls, *args):
        if len(args) != len(cls._field_names):
            raise TypeError(f"Expected {len(cls._field_names)} args")
        return super().__new__(cls, args)


class Point(NamedTupleBase):
    _field_names = ('x', 'y')


if __name__ == "__main__":
    p = Point(1, 2)
    print(p.x, p.y)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值