Точные обстоятельства очевидно очень характерны для Вашего проекта (например, группа разработчиков, стиль управления, обработайте зрелость, трудность темы, и т.д.). Для обзора этого немного лучше, таким образом, мы можем говорить об этом в чем-либо кроме широких упрощений, я собираюсь вновь заявить вопросе:
, При каких обстоятельствах, если таковые имеются, может, добавляя членов команды к проекту разработки программного обеспечения, который выполняет последний результат в сокращении фактической даты поставки с уровнем качества, равного этому, если существующие команды были, позволяют работать до завершения?
существует много вещей, что я думаю, необходимы , но не достаточные, для этого для появления (без определенного порядка):
Одна из первых вещей, которые должны быть обсуждены, - может ли дата поставки быть подсунутой, могут ли функции быть сокращены, и если некоторые комбинации этих двух позволят Вам удовлетворять выпуск своим существующим штатом. Много раз это - пара функций, которые являются действительно hogging ресурсами команды, которая не поставит значение, равное инвестициям. Поэтому отдайте приоритеты своего проекта серьезный обзор перед чем-либо еще.
, Если результат вышеупомянутого абзаца не достаточен, то посетите список выше. При ловле промаха расписания рано добавление правильных членов команды в нужное время может сохранить выпуск. К сожалению, чем ближе Вы добираетесь до своей ожидаемой даты поставки, тем больше вещей может пойти не так, как надо с добавляющими людьми. Однажды, Вы пересечете "точку невозврата", где никакое количество изменения (кроме поставки текущего ответвления разработки) не может сохранить Ваш выпуск.
я мог продолжить и на, но я думаю, что поразил важные пункты. За пределами проекта и с точки зрения Вашей карьеры, будущего успеха компании, и т.д. одна из вещей, которые необходимо определенно сделать, выяснить, почему Вы опаздывали, если что-нибудь, возможно, было сделано предупреждение Вы ранее, и что измеряет Вас, должен взять для предотвращения его в будущем. Последний проект обычно происходит, потому что Вы были также:
Hope, которая помогает!
Наверное, не совсем то, о чем вы думали, но ...
q = request.GET.get('q')
if q:
print q
это?
См. Мой рецепт 8-летней давности здесь только для этой задачи.
# In Python, you can't code "if x=foo():" -- assignment is a statement, thus
# you can't fit it into an expression, as needed for conditions of if and
# while statements, &c. No problem, if you just structure your code around
# this. But sometimes you're transliterating C, or Perl, or ..., and you'd
# like your transliteration to be structurally close to the original.
#
# No problem, again! One tiny, simple utility class makes it easy...:
class DataHolder:
def __init__(self, value=None): self.value = value
def set(self, value): self.value = value; return value
def get(self): return self.value
# optional but handy, if you use this a lot, either or both of:
setattr(__builtins__,'DataHolder',DataHolder)
setattr(__builtins__,'data',DataHolder())
# and now, assign-and-set to your heart's content: rather than Pythonic
while 1:
line = file.readline()
if not line: break
process(line)
# or better in modern Python, but quite far from C-like idioms:
for line in file.xreadlines():
process(line)
# you CAN have your C-like code-structure intact in transliteration:
while data.set(file.readline()):
process(data.get())
Ну, это будет односторонний
q = request.GET.get('q')
if q:
print q
Более короткий (но не лучший, из-за призыва «ничего не печатать») будет
print request.GET.get('q') or '',
q = request.GET.get('q')
if q:
print q
else:
# q is None
...
Невозможно выполнить присваивание и условные обозначения за один раз ...
Если get () выдает исключение, когда его нет, вы можете сделать
try:
q = request.GET.get('q')
print q
except :
pass
Вариант Ответ Алекса :
class DataHolder:
def __init__(self, value=None, attr_name='value'):
self._attr_name = attr_name
self.set(value)
def __call__(self, value):
return self.set(value)
def set(self, value):
setattr(self, self._attr_name, value)
return value
def get(self):
return getattr(self, self._attr_name)
save_data = DataHolder()
Использование:
if save_data(get_input()):
print save_data.value
или, если вы предпочитаете альтернативный интерфейс:
if save_data.set(get_input()):
print save_data.get()
Я считаю это полезным для тестирования серии регулярных выражений в конструкции if-elif-elif-elif и т. д., как в этот вопрос SO :
import re
input = u'test bar 123'
save_match = DataHolder(attr_name='match')
if save_match(re.search('foo (\d+)', input)):
print "Foo"
print save_match.match.group(1)
elif save_match(re.search('bar (\d+)', input)):
print "Bar"
print save_match.match.group(1)
elif save_match(re.search('baz (\d+)', input)):
print "Baz"
print save_match.match.group(1)
config_hash = {}
tmp_dir = ([config_hash[x] for x in ["tmp_dir"] if config_hash.has_key(x)] or ["tmp"])[0]
print tmp_dir
config_hash["tmp_dir"] = "cat"
tmp_dir = ([config_hash[x] for x in ["tmp_dir"] if config_hash.has_key(x)] or ["tmp"])[0]
print tmp_dir