modulefinder
— Найти модули, используемые сценарием¶
Исходный код: Lib/modulefinder.py.
Этот модуль предоставляет класс ModuleFinder
, который можно использовать для определения набора модулей, импортированных скриптом. modulefinder.py
можно также запустить как сценарий, указав в качестве аргумента имя файла сценария Python, после чего будет напечатан отчет об импортированных модулях.
-
modulefinder.
AddPackagePath
(pkg_name, path)¶ Запись того, что пакет с именем pkg_name может быть найден в указанном path.
-
modulefinder.
ReplacePackage
(oldname, newname)¶ Позволяет указать, что модуль с именем oldname на самом деле является пакетом с именем newname.
-
class
modulefinder.
ModuleFinder
(path=None, debug=0, excludes=[], replace_paths=[])¶ Этот класс предоставляет методы
run_script()
иreport()
для определения набора модулей, импортируемых скриптом. path может быть списком каталогов для поиска модулей; если он не указан, используетсяsys.path
. debug задает уровень отладки; более высокие значения заставляют класс печатать отладочные сообщения о том, что он делает. excludes - список имен модулей, которые нужно исключить из анализа. replace_paths - список кортежей(oldpath, newpath)
, которые будут заменены в путях модулей.-
report
()¶ Выведите на стандартный вывод отчет, в котором перечислены модули, импортированные скриптом, и пути к ним, а также модули, которые отсутствуют или кажутся отсутствующими.
-
run_script
(pathname)¶ Проанализируйте содержимое файла pathname, который должен содержать код Python.
-
modules
¶ Словарь, отображающий имена модулей на модули. См. Пример использования ModuleFinder.
-
Пример использования ModuleFinder
¶
Сценарий, который будет анализироваться позже (bacon.py):
import re, itertools
try:
import baconhameggs
except ImportError:
pass
try:
import guido.python.ham
except ImportError:
pass
Сценарий, который выведет отчет bacon.py:
from modulefinder import ModuleFinder
finder = ModuleFinder()
finder.run_script('bacon.py')
print('Loaded modules:')
for name, mod in finder.modules.items():
print('%s: ' % name, end='')
print(','.join(list(mod.globalnames.keys())[:3]))
print('-'*50)
print('Modules not imported:')
print('\n'.join(finder.badmodules.keys()))
Образец вывода (может отличаться в зависимости от архитектуры):
Loaded modules:
_types:
copyreg: _inverted_registry,_slotnames,__all__
sre_compile: isstring,_sre,_optimize_unicode
_sre:
sre_constants: REPEAT_ONE,makedict,AT_END_LINE
sys:
re: __module__,finditer,_expand
itertools:
__main__: re,itertools,baconhameggs
sre_parse: _PATTERNENDERS,SRE_FLAG_UNICODE
array:
types: __module__,IntType,TypeType
---------------------------------------------------
Modules not imported:
guido.python.ham
baconhameggs