1

假设我们有一段错误的代码不小心覆盖了某个系统库的属性,如下所示:

import socket
socket.error = 'some other object'

有没有办法防止这种行为,或者找到负责这样做的代码?

我尝试从 socket.error 中创建一个属性,但这不起作用:

def fget(self):
    return socket.error

def fset(self, value):
    raise SystemError('You cannot alter this attribute.')

# From now on, settings socket.error = x should raise an error
socket.error = property(fget, fset)
4

1 回答 1

6

您可以(暂时)将其粘贴在您的代码中:

class Bridge(object):
    def __init__(self, module):
        self.__dict__['module'] = module
    def __getattr__(self, attr):
        return getattr(self.module, attr)
    def __setattr__(self, attr, val):
        raise TypeError('{a!r} can not be set'.format(a=attr))

import sys
import socket
socket = sys.modules['socket'] = Bridge(socket)

然后设置属性socket(至少以最常用的方式)会引发异常。回溯将允许您定位错误。

print(socket.error)
setattr(socket, 'error', 'blah')

产量

% test.py
<class 'socket.error'>
Traceback (most recent call last):
  File "/home/unutbu/pybin/test.py", line 15, in <module>
    setattr(socket, 'error', 'blah')
  File "/home/unutbu/pybin/test.py", line 10, in __setattr__
    raise TypeError('{a!r} can not be set'.format(a=attr))
TypeError: 'error' can not be set
于 2013-03-18T17:01:03.367 回答