Python标准库中是否有一个函数可以重现具有“私有”属性名称的Python名称修改方案?好像会有,但我找不到它的生命。
我写了这篇文章,但如果有更好的方法我会全神贯注。
def mangle_name (cls, attrname) :
prefix = '_' + cls.__name__.lstrip('_')
if not attrname.startswith('__') :
attrname = '__' + attrname
if not attrname.endswith('__') :
return prefix + attrname
else :
return attrname
class Foo :
__some_such = 3
name = mangle_name(Foo, '__some_such')
print name
print hasattr(Foo(), name)
答案 0 :(得分:14)
看起来compiler模块有一个Python实现,签名是mangle(name, klass)
,其中klass
是类名,而不是对象本身。
以下是访问和使用它的方法:
>>> from compiler.misc import mangle
>>> mangle('__some_such', 'Foo')
'_Foo__some_such'
请注意,编译器模块自Python 2.6起就不推荐使用,而且在Python 3.0中不存在。
以下是函数本身(来自Python 2.7 source code),以防您只想将其复制到源代码中或验证您的版本是否相同:
MANGLE_LEN = 256 # magic constant from compile.c
def mangle(name, klass):
if not name.startswith('__'):
return name
if len(name) + 2 >= MANGLE_LEN:
return name
if name.endswith('__'):
return name
try:
i = 0
while klass[i] == '_':
i = i + 1
except IndexError:
return name
klass = klass[i:]
tlen = len(klass) + len(name)
if tlen > MANGLE_LEN:
klass = klass[:MANGLE_LEN-tlen]
return "_%s%s" % (klass, name)