前缀单下划线,如:_name
某个方法或变量如果使用了此格式命名只是提醒开发者这并不是要组成公共接口的,对于普通的单文件内的变量或方法来说,并没有实际限制作用。但是用此格式命名的变量或方法无法被from import显式导入所导入,除非被__all__列表限制。
如下所示:
# a.py
_name = 'value'
# b.py
import a
print(a._name) # 正常打印:'value'
# c.py
from a import *
print(_name) # NameError: name '_name' is not defined
# d.py
_name = 'value'
__all__ = ['_name']
# e.py
from d import *
print(_name) # 正常打印:'value'
后缀单下划线,如:name_
如果一个方法名或变量名和原定关键词或方法名冲突,则使用此格式命名。如,原先想定义一个名称叫print的方法,可是print已经成为一个既定的方法名,于是可以定义一个名称叫print_的方法名防止冲突。
前缀双下划线,如:__name
class Cls:
__name = 'value'
def getName(self):
return self.__name
print(Cls().__name) # AttributeError: 'Cls' object has no attribute '__name'
print(Cls()._Cls__name) # 正常打印:'value'
print(Cls().getName()) # 正常打印:'value'
前后各双下划线,如:__name__
此情况和上述前缀双下划线不同,用此格式命名并不会触发名称更改。但用此格式命名的变量或方法一般是Python保留而用于特殊目的的,如__init__、__name__等。应当尽量避免自己的变量名或方法名为此格式。
仅单下划线,如:_
一般用“_”命名那些并不重要的、用不到的变量名。
如下所示:
# 如果我们想要打印十次value...
for _ in range(10):
print('value')
标签:__,代表,下划线,Python,value,print,Cls,name
From: https://www.cnblogs.com/XuShuo-Self/p/17090710.html