python魔法方法__add__、__sub__实现时间的加减

代码如下:

from typing import Union


class Hour:
    MINUTES = 60

    def __init__(self, s: Union[str, int] = 0, minute: int = 0):
        if isinstance(s, str) and "h" in s:
            self.hour, self.minute = map(int, s.split("h"))
        else:
            self.hour, self.minute = int(s), minute

    def __str__(self):
        return f"{self.hour}h{self.minute:02}"

    @property
    def mins(self) -> int:
        if self.hour < 0:
            return self.hour * self.MINUTES - self.minute
        return self.hour * self.MINUTES + self.minute

    @classmethod
    def from_minutes(cls, value: str):
        if value == 0:
            return cls()
        if value > 0:
            hour = value // cls.MINUTES
        else:
            value *= -1
            hour = -(value // cls.MINUTES)
        minute = value % cls.MINUTES
        return cls(hour, minute)

    def __add__(self, other):
        return self.from_minutes(self.mins + other.mins)

    def __sub__(self, other):
        return self.from_minutes(self.mins - other.mins)


def main():
    assert str(Hour("10h00") - Hour("5h00")) == "5h00"
    print(
        Hour("3h30"),
        "-",
        Hour("10h00"),
        "=",
        Hour("3h30") - Hour("10h00"),
        '  # expected: "-6h30"',
    )
    print('"1h00" - "2h00" = "-1h00"')
    print(Hour("1h00") - Hour("2h00"))
    print(Hour("1h00") - Hour("-2h00"), "  # expected: 3h00")
    print(Hour("1h30") - Hour("-2h00"), "  # expected: 3h30")
    print(Hour("-1h00") - Hour("2h00"), "  # expected: -3h00")
    print(Hour("-1h30") - Hour("-2h00"), "  # expected: 0h30")
    print(Hour("-1h30") + Hour("0h30"))


if __name__ == "__main__":
    main()

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值