区别:

xx:公有变量,所有对象都可以访问;

xxx:双下划线代表着是系统定义的名字。
__xxx:双前置下划线,避免与子类中的属性命名冲突,无法在外部直接访问。代表着类中的私有变量名。
_xxx:单前置下划线,私有化属性和方法,类对象和子类可以访问。不能用“from module import *”导入。
xx_:单后置下划线,用于避免与python关键字的冲突。

Python中存在一些特殊的方法,有些方法以双下划线 “__” 开头和结尾,它们是Python的魔法函数,比如__init__()和__str__等等。不用要这种方式命名自己的变量或者函数。
示例代码:

class Test(object):def __init__(self, text):self.text = text def __str__(self):return self.texttext = input("Please input text:")obj = Test(text)print(obj)

运行结果:


在前面加上“__”,表示它是私有成员,我们不能直接访问。比如 “__xxx” 如果要访问得通过 _class__xxx 的方式进行访问。虽然不能防止修改私有属性,但可以有效降低有意或者无意的修改。

示例代码:

class Test(object):def __init__(self, text):self.__text = textself.__text2 = text def func(self):print(self.__text) def __str__(self):return self.__texttext = input("Please input text:")obj = Test(text)print(obj)obj.func()#print(obj.__text)# 报错print(obj._Test__text)print(dir(obj))

运行效果:


从图中可以看到双下划线开头的变量,Python自动在前面加上了 “_class” 的前缀,所以我们访问时也要加上相应的前缀才能正常访问。

_xxx:一种约定,用来指定变量私有。程序员用来指定私有变量的一种方式。不能用from module import * 导入,其他方面和公有一样访问。

示例代码:

#test.pyclass Test1(object):def __init__(self):self.text = "my is text!" def __str__(self):return self.textclass _Test2(object):def __init__(self):self.text = "my is text2!" def __str__(self):return self.textif __name__ == '__main__':obj1 = Test1()obj2 = _Test2()print(obj1)print(obj2)


可以通过别的方式访问这个类,修改我们的test2.py文件为以下内容。

#test2.pyimport test obj1 = test.Test1()print(obj1)obj2 = test._Test2()print(obj2)

除了不能通过 from module import * 这种方式导入外,跟公有类并没有差别。

运行效果:

__sizeof__() : 打印系统分配空间的大小。
示例代码:

class Test(object):def __init__(self):self.__text = "my is text!" def func(self):print(self.__text) def __str__(self):return self.__textobj = Test()print(obj)print(dir(obj))print("*" * 100)print(obj.func.__sizeof__())print(obj.func.__sizeof__)print("*" * 100)print(obj.func().__sizeof__)print(obj.func().__sizeof__())

运行结果:


__name__:前面和后面加上下划线代表着是系统定义的名字。普通变量不能使用此方式来命名。__name_表示当前模块执行过程中的名称,如果该模块执行,则__name__的值为__main_,如果模块是被导入的,则__name__的值为被导入的模块的模块名字。

__main__:表示整个工程开始运行的入口。
示例代码:

#test_name.pydef func():if __name__ == '__main__':print("my name is %s" % __name__)# my name is __main__else:print("It's me: %s" % __name__)# It's me: test_nameif __name__ == '__main__':func()# my name is __main__ #在其它文件中#test_name2.pyimport test_name test_name.func()# It's me: test_name