Вы можете передать lambda для оценки как условие if
.
Попробуйте:
validates :description, presence: true, if: -> { first_step? || require_validation }
Как насчет:
for name in 'a', 'b', 'c':
try:
thing = getattr(obj, name)
except AttributeError:
pass
else:
break
Может быть лучший способ сделать это в зависимости от структуры вашего объекта, но ничего не зная, вот рекурсивное решение, которое работает точно так же, как ваше текущее решение, за исключением того, что оно будет работать с произвольным числом аргументов:
g = lambda o, l: getattr(o, l[0], g(o, l[1:])) if l else None
Я думаю, что использование dir будет получать по существу то же самое, что __dict__
обычно делает ...
targetValue = "value"
for k in dir(obj):
if getattr(obj,k) == targetValue:
print "%s=%s"%(k,targetValue)
что-то вроде
>>> class x:
... a = "value"
...
>>> dir(x)
['__doc__', '__module__', 'a']
>>> X = x()
>>> dir(X)
['__doc__', '__module__', 'a']
>>> for k in dir(X):
... if getattr(X,k) == "value":
... print "%s=%s"%(k,getattr(X,k))
...
a=value
>>>
И еще один:
reduce(lambda x, y:x or getattr(obj, y, None), "a b c".split(), None)
(в Python 3 вам нужно импортировать сокращение из functools. Он встроен в Python 2)
bool(obj.b)
имеет значение True. Подумайте, что произойдет здесь, если у вас есть obj.a = 0
. Я не думаю, что ты заберешь это.
– mgilson
28 November 2012 в 03:15
Это имеет преимущество в работе с любым количеством элементов:
def getfirstattr(obj, *attrs):
return next((getattr(obj, attr) for attr in attrs
if hasattr(obj, attr)), None)
У этого есть незначительный недостаток very , который выполняет два поиска по окончательному значению: один раз чтобы убедиться, что атрибут существует, другой для фактического получения значения. Этого можно избежать, используя выражение вложенного генератора:
def getfirstattr(obj, *attrs):
return next((val for val in (getattr(obj, attr, None) for attr in attrs)
if val is not None), None)
Но я действительно не чувствую, что это большое дело. Выражение генератора, вероятно, будет быстрее, чем простой старый цикл даже с двойным поиском.
hasattr
и один раз с getattr
). В конечном счете, я решил, что это было не лучше, чем явный цикл, отправленный wim. Хотя я открыт для слушания о каких-либо преимуществах, которые могут возникнуть в течение цикла.
– mgilson
28 November 2012 в 02:35
else
для цикла for, если это то, что вам нужно. Что касается стиля, то в python обычно присутствует множество try / excepts - см. EAFP – wim 28 November 2012 в 05:16