python里面单双下划线的区别详解

 更新时间:2023年04月24日 08:31:06   作者:WTIAW.TIAW  
本文主要介绍了python里面单双下划线的区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

区别:

  • 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.text
 
 
text = input("Please input text:")
obj = Test(text)
print(obj)

运行结果:

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

示例代码:

class Test(object):
    def __init__(self, text):
        self.__text = text
        self.__text2 = text
 
    def func(self):
        print(self.__text)
 
    def __str__(self):
        return self.__text
 
 
text = 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.py
class Test1(object):
    def __init__(self):
        self.text = "my is text!"
 
    def __str__(self):
        return self.text
 
 
class _Test2(object):
    def __init__(self):
        self.text = "my is text2!"
 
    def __str__(self):
        return self.text
 
 
if __name__ == '__main__':
    obj1 = Test1()
    obj2 = _Test2()
    print(obj1)
    print(obj2)

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

#  test2.py
import 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.__text
 
 
obj = 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.py
def 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_name
 
 
if __name__ == '__main__':
    func()  # my name is __main__
 
#  在其它文件中
#  test_name2.py
import test_name
 
test_name.func()  # It's me: test_name

到此这篇关于python里面单双下划线的区别详解的文章就介绍到这了,更多相关python 单双下划线区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

最新评论