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__
re._compiler:  isstring,_sre,_optimize_unicode
_sre:
re._constants:  REPEAT_ONE,makedict,AT_END_LINE
sys:
re:  __module__,finditer,_expand
itertools:
__main__:  re,itertools,baconhameggs
re._parser:  _PATTERNENDERS,SRE_FLAG_UNICODE
array:
types:  __module__,IntType,TypeType
---------------------------------------------------
Modules not imported:
guido.python.ham
baconhameggs