Python的优良做法:将变量名称作为参数

Syr*_*tem 5 python python-2.7

很确定我知道这个问题的答案,但是想问问python社区.

我正在开发一个python项目,目前的趋势是剪切变量名或类名,将其作为参数传递给其他方法...喜欢:

myVar.__classname__[6:] 
Run Code Online (Sandbox Code Playgroud)

或最坏的:

try :
    ...
except Error as err :
    myVar = err.message.split(':')[0]
    getattr(myInst, myVar)
Run Code Online (Sandbox Code Playgroud)

... ...说,我们必须尊重一个非常严格的命名约定,这将符合所有那些可怕的代码行,但我想知道这是否是一种常见的做法,我是完全脱离了行,或者如果我是没错,说这只是......太可怕了.

对我来说这似乎是一个非常糟糕的主意,但我们别无选择......

感谢任何有助于我的回复

编辑:这是try/except中的实际代码,如果您想了解更多详细信息:

except ValueError as err:
    field_error = self.klass.__name__ + '_' + err.message.split(':')[0]
    getattr(self.ui, field_error).setText(err.message) 
Run Code Online (Sandbox Code Playgroud)

编辑:所以有些人要求更多细节:

在上面的示例中,我们想在用户输入的值错误时在字段中设置错误消息.

self.klass表示SQL Alchemy类,"命名约定"表示每个字段应该以它前面的SQL Alchemy类名开头,然后是下划线,然后是我们设置错误消息的字段(当前相同)用户输错了).

这将"构建"(哦上帝......这感觉很糟糕)ui字段的名称是错误的,然后我们将通过一般ui上的getattr得到它.

这感觉非常错误,因为它基于一个命名约定,当我们开始有更多类时可能有数十亿例外...实际上,我不介意修复它,但整个项目都是基于这个命名约定.第一个例子基于这样一个事实:我们的应用程序有不同的ui文件,并且这些文件由代码索引(如7CDGR01).然后由类完成这些以添加行为(信号处理......等).如果我保留相同的示例,则该类名为:Screen7CDGR01.因此,要获得屏幕的代码,您将从第6个字符开始获取类名的结尾...然后将其发送到另一个方法等等...

认为你都得到了,这不是我投票的,我觉得这很糟糕,我不是python的专家,但我认为即使python允许我们做很多,也不应该像那样使用.

luc*_*asg 3

对变量/类名使用内省是危险的,因为在 Python 中,名称不一致:Python introspection: access function name and docstring inside functionDefinition

#!/usr/local/bin/python2.7


class myInst(): 
  iitt = 15
  pass

class deco():
    def __init__(self, id, *args, **kws):
        self.__id = id
        self.iitt = 25
        self.__name__ = "another name"

@deco
class myInst2():
  iitt = 15
  pass


# Overriding class name
print "MyInst name :", myInst.__name__    #"myInst"
print "MyInst2 name :", myInst2.__name__  #"another name"


# Overriding attribute value
try:
  raise ValueError("iitt: Error!")
except ValueError as err:
  myVar = err.message.split(':')[0]
  l = getattr(myInst, myVar)
  print l                                 # 15

try:
  raise ValueError("iitt: Error!")
except ValueError as err :
  myVar = err.message.split(':')[0]
  l = getattr(myInst2, myVar)
  print l                                 # 25

#Duck Typing
myInst = myInst2
try:
  raise ValueError("iitt: Error!")
except ValueError as err :
  myVar = err.message.split(':')[0]
  l = getattr(myInst, myVar)
  print l                                 # 25
Run Code Online (Sandbox Code Playgroud)