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