Python Toolkit to imports introspection
Project description
Be aware about imports meta information
Source Code: https://github.com/andresbena19/py-imports
Requirements :wrench: :hammer: :nut_and_bolt:
Python 3.7+
py-imports stands on the shoulders of giants:
- ast — Abstract Syntax Trees to traverse python code.
Installation :computer:
$ pip install py-imports
---> 100%
All it's ready to begin
Example :paperclip:
Introspect it
- Create a file
main.py
with:
import logging
from py_imports.manager import PyImports
from .parse_local_dir import file_imports_from_dir_one
myself = "main.py"
# Let's introspect myself
with PyImports() as manager:
imports_file = manager.get_imports(myself)
# Now you have access to the imports used in each file
imports_file
{
'main.py': <py_imports.base.models.ImportsCollectionFile object at 0x10b889220>
}
# Get details about the absolute, relative and standard imports in the file
collector_object = imports_file.get(myself)
absolute_imports = collector_object.absolute_imports
relative_imports = collector_object.relative_imports
standard_imports = collector_object.imports
Get meta information about absolute imports...absolute_imports
# Absolute imports
# --- from py_imports.manager import PyImports ---
# If we introspect the object, we will get the following
example_abs_import = absolute_imports[0]
example_abs_import.children -> ['PyImports']
example_abs_import.parent -> 'py_imports.manager'
example_abs_import.statement -> 'from py_imports.manager import PyImports'
example_abs_import.level -> 0
example_abs_import.line -> 2
Get meta information about relative imports...relative_imports
# relative imports
# --- from .parse_local_dir import file_imports_from_dir_one ---
# If we introspect the object, we will get the following
example_relative_import = relative_imports[0]
example_abs_import.children -> ['file_imports_from_dir_one']
example_abs_import.children_unused -> ['file_imports_from_dir_one']
example_abs_import.parent -> 'parse_local_dir'
example_abs_import.statement -> 'from .parse_local_dir import file_imports_from_dir_one'
example_abs_import.level -> 1
example_abs_import.line -> 3
Get meta information about standard imports ...standard_imports
# standard imports
# --- import logging ---
# If we introspect the object, we will get the following
example_standard_import = standard_imports[0]
example_standard_import.children -> ['logging']
example_standard_import.children_unused -> ['logging']
example_standard_import.statement -> 'import logging'
example_standard_import.line -> 1
Now you know more about you... :lotus_position:
Features :sunny:
:sunglasses: Classify the imports found into three groups
- Python Abstract Grammar
| Import(alias* names)
| ImportFrom(identifier? module, alias* names, int? level)
-
Relative Imports
Relative imports use leading dots. A single leading dot indicates a relative import, starting with the current package. Two or more leading dots indicate a relative import to the parent(s) of the current package, one level per dot after the first.
-
Schema syntax
Relative imports must always usefrom <> import
;import <>
is always absolute.- pydocs: https://docs.python.org/3/reference/import.html#package-relative-imports
- Metadata will be abstracted in
RelativeImportStatement
objects.
-
Ex.
from .moduleY import spam from .moduleY import spam as ham from . import moduleY from ..subpackage1 import moduleY from ..subpackage2.moduleZ import eggs from ..moduleA import foo from ...package import bar from ...sys import path
-
-
Absolute Imports
Absolute import involves full path i.e., from the project’s root folder to the desired module. An absolute import state that the resource
to be imported using its full path from the project’s root folder.-
Schema syntax
Absolute imports may use either theimport <>
orfrom <> import <>
syntax, but relative imports may only use the second form.- PEP328: https://www.python.org/dev/peps/pep-0328/
- Metadata will be abstracted in
AbsoluteImportStatement
objects.
-
Ex.
from moduleY import spam from moduleY import spam as ham # OR import XXX.YYY.ZZZ
-
-
Standard Imports
Standard imports will be introspected and the data about it will be saved in an object named
ImportStatement
.-
Schema syntax
standard imports use theimport <>
syntax.- PEP328: https://www.python.org/dev/peps/pep-0328/
- Metadata will be abstracted in
ImportStatement
objects.
-
Ex.
import moduleY import moduleX
-
:sunglasses: Validate if the imports are being used
-
Unused imports
If some child it's not used in an import, this will be added in
children_unused
attribute in every concrete implementation that represent an imports.from ..subpackage1 import moduleY, moduleZ def foo() -> moduleZ: pass
In this case the relative import
from ..subpackage1 import moduleY, moduleZ
has a child that is not used in the file.... # After introspect the file relative_imports = imports_file.relative_imports relative_imports[0].children_unused = ["moduleY"] # But the total of children present in this file relative_imports[0].children = ["moduleY", "moduleZ"]
:eyes: it's used
pyflakes
to determine the unused imports, because follow the same philosophy to get the information just using a static analysis.
Notes :bookmark:
This library does not execute any part of the python target code, this just make a static analysis over the code to describe the meta information about the imports in the file.
License :traffic_light:
This project is licensed under the terms of the MIT license.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file py_imports-1.2.0.tar.gz
.
File metadata
- Download URL: py_imports-1.2.0.tar.gz
- Upload date:
- Size: 10.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.11 CPython/3.10.0 Linux/5.11.0-1020-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ff9541518c2612cdb37689ca5eeed5d140263b852614b0d0c9edd4686b607c8e |
|
MD5 | bb577575f8259a62704a1d7589dfa14a |
|
BLAKE2b-256 | e1720b842bf0d419712694177cfe13801c83f88dadc9c438a0fd313693871b7d |
File details
Details for the file py_imports-1.2.0-py3-none-any.whl
.
File metadata
- Download URL: py_imports-1.2.0-py3-none-any.whl
- Upload date:
- Size: 8.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.11 CPython/3.10.0 Linux/5.11.0-1020-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8869c843c945c7a6292b3c66291ff1c88ff6afc77774caa2a99cbf28f9f56b49 |
|
MD5 | 9c8426bac7787ff6fb721b694f0e9a4b |
|
BLAKE2b-256 | ed9bf197fe63c4447e033d306715af69b16427775f46263b86dd84fe4479da08 |