加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – 以任何方式使用时引发异常的对象

发布时间:2020-12-16 23:47:33 所属栏目:Python 来源:网络整理
导读:我需要创建一个对象,当它以任何方式使用时会引发自定义异常UnusableObjectError(尽管创建它不应该创建异常). a = UnusableClass() # No errorb = UnusableClass() # No errora == 4 # Raises UnusableObjectError'x' in a # Raises UnusableObjectErrorfor i

我需要创建一个对象,当它以任何方式使用时会引发自定义异常UnusableObjectError(尽管创建它不应该创建异常).

a = UnusableClass()     # No error
b = UnusableClass()     # No error
a == 4                  # Raises UnusableObjectError
'x' in a                # Raises UnusableObjectError
for i in a:             # Raises UnusableObjectError
    print(i)

# ..and so on

我想出了下面的代码,它看起来像预期的那样.

class UnusableObjectError(Exception):
    pass

CLASSES_WITH_MAGIC_METHODS = (str(),object,float(),dict())

# Combines all magic methods I can think of.
MAGIC_METHODS_TO_CHANGE = set()
for i in CLASSES_WITH_MAGIC_METHODS:
    MAGIC_METHODS_TO_CHANGE |= set(dir(i))
MAGIC_METHODS_TO_CHANGE.add('__call__')
# __init__ and __new__ must not raise an UnusableObjectError
# otherwise it would raise error even on creation of objects.
MAGIC_METHODS_TO_CHANGE -= {'__class__','__init__','__new__'}


def error_func(*args,**kwargs):
    """(nearly) all magic methods will be set to this function."""
    raise UnusableObjectError


class UnusableClass(object):
    pass

for i in MAGIC_METHODS_TO_CHANGE:
    setattr(UnusableClass,i,error_func)

(根据评论中的Duncan建议进行了一些改进)

问题:
是否存在一个行为与描述相同的类?

如果没有,我的UnusableClass()中是否有任何缺陷(例如,使用类实例的情况不会引发错误),如果是这样,我该如何解决这些缺陷?

最佳答案
事实证明,元类和dunder(双下划线)方法并不能很好地结合在一起(这是不幸的,因为这将是一种更简化的实现方法).

我找不到任何可导入的魔术方法名称列表,所以我创建了一个并将其放在PyPi(https://pypi.python.org/pypi/magicmethods/0.1.1)上.有了它,UnusableClass的实现可以写成一个简单的类装饰器:

import magicmethods

class UnusableObjectError(Exception): 
    pass

def unusable(cls):
    def _unusable(*args,**kwargs):
        raise UnusableObjectError()

    for name in set(magicmethods.all) - set(magicmethods.lifecycle):
        setattr(cls,name,_unusable)
    return cls

@unusable
class UnusableClass(object):
    pass

magicmethods.lifecycle包含__new __,__ init__和__del__.你可能想调整这个..

此实现还处理:

a = UnusableClass()
with a:
    print 'oops'

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读