Python名称修改功能

时间:2012-06-13 22:37:37

标签: python oop name-mangling

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)

1 个答案:

答案 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)