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
Вернуться на верх