Объединяем все вместе
Последняя строка кода и единственная еще не разобранная — делает всю работу. Но теперь задача совсем проста, так как все, что нам необходимо, уже готово. Все костяшки домино на месте, осталось только толкнуть их.
Пример 2.25. Основная часть apihelper.py
print "\n".join(["%s %s" % (method.ljust(spacing), processFunc(str(getattr(object, method).__doc__))) for method in methodList])
Обратите внимание, что это одна команда разбитая на несколько строк без явного использования признака продолжения (“\”). Помните, я говорил, что без использования обратного слэша? Расширенная запись списков — один из таких случаев, так как все выражение заключено в квадратные скобки.
Давайте разберем его с конца. Фраза
for method in methodList
говорит о том, ято мы имеем дело с . Как вы уже знаете, methodList является списком объекта object. Таким образом мы пробегаем по списку методов и каждый метод доступен через переменную method.
Пример 2.26. Динамическое извлечение строки документации
>>> import odbchelper >>> object = odbchelper
>>> method = 'buildConnectionString'
>>> getattr(object, method)
<function buildConnectionString at 010D6D74> >>> print getattr(object, method).__doc__
Создает и возвращает строку соединения из словаря параметров.
В функцию help object — объект, для которого мы хотим получить помощь — передается в качестве аргумента. | |
По ходу того, как мы пробегаем по списку methodList, method содержит имя текущего метода. | |
С помощью функции мы получаем сам метод method объекта object. | |
Теперь осталось самое простое — распечатать строку документации метода. |
Следующий кирпичик — использование функции str. Как вы уже знаете, str — встроенная функция, . Но строка документации уже является строкой, так зачем же суетиться с использованием функции str? На самом деле не каждая функция имеет строку документации, и если строки документации нет, ее атрибут __doc__ равен None.
Пример 2.27. Зачем использовать str для строк документации?
>>> {}.keys.__doc__
>>> {}.keys.__doc__ == None
1 >>> str({}.keys.__doc__)
'None'
Метод keys словаря не имеет строки документации, так что его атрибут __doc__ равен None. Если вы набираете выражение для атрибута __doc__ непосредственно в интерактивном режиме, интерпретатор Python ничего не выводит, что может сбить с толку (такое поведение интерпретатора действительно удобно, если впомнить о процедурах, которые в языке Python возвращают None). | |
Вы можете убедиться, что атрибут __doc__ действительно равен None простым сравнением. | |
Функция str возвращает строковое представление объекта, в данном случае 'None'. |
В SQL вы должны использовать IS NULL вместо = NULL для сравнения с пустым значением. В языке Python вы можете использовать как == None, так и is None, но второй вариант работает быстрее. |
для None будет сгенерировано исключение, так как у None нет метода split.
Далее мы снова используем форматирование, чтобы соединить значение, возвращаемое функцией processFunc, со результатом применения метода ljust к строке method. Это новый метод строковых объектов, который мы раньше не видели.
Пример 2.28. Метод ljust
>>> s = 'buildConnectionString' >>> s.ljust(30)
'buildConnectionString ' >>> s.ljust(20)
'buildConnectionString'
ljust дополняет строку пробелами до указанной длины. Именно это делает функция help при выводе в две колонки для выравнивания строк документации во второй колонке. | |
Если требуемая длина меньше, чем исходная длина строки, ljust вернет строку без изменений. Этот метод никогда не обрезает строку. |
Имея метод ljust, дополняющий имя метода пробелами до нужной длины, и строку документации (возможно со свернутыми символами пропуска), которую возвращает processFunc, мы объединяем их и получаем одну строку. Так как мы пробегаем по списку methodList, то получим список строк. Используя метод join
строки "\n", мы объединяем строки в одну с символом перехода на новую строку в качестве разделителя и печатаем результат.
Пример 2.29. Печать списка
>>> li = ['a', 'b', 'c'] >>> print "\n".join(li)
a b c
Этот прием также будет будет полезен при отладке для вывода списков. А в языке Python вы будете работать со списками постоянно. |
Пример 2.30. Основная часть apihelper.py, пересмотренная
print "\n".join(["%s %s" % (method.ljust(spacing), processFunc(str(getattr(object, method).__doc__))) for method in methodList])
8 | ||
Copyright © 2000, 2001, 2002 Copyright © 2001, 2002, 2003 Перевод, |