change the message in ModuleNotFoundError
Project description
friendly_module_not_found_error
This is a Python package that provides a custom exception class for handling module not found errors in a friendly way.
Installation
To install the package, run the following command:
pip install friendly_module_not_found_error
Usage
Don't need to import the packages. The pth file is already in the site-packages folder.
You can use the code to test the effects of the package:
import ant
The message raised will change to : "No module named 'ant'. Did you mean 'ast'?"
import multiprocessing.dumy
The message raised will change to : "module 'multiprocessing' has no child module 'dumy'. Did you mean 'dummy'?"
You can also run "test/test.py" to test the effects of the python.
require
python3.12+
Below it, the suggestion cannot be supported. The change that python suggest the similar name in "traceback.py" is in "3.12".
License
This package is licensed under the MIT License. See the LICENSE file for more information.
issues
If you have any questions or suggestions, please open an issue on GitHub.
Contributing
Contributions are welcome! Please submit a pull request with your changes.
Note
If a module that is not a package contains submodules, and those submodules also contain their own submodules, this nested module structure is not supported. When this situation occurs, you should reorganize the code using proper package structure. This approach violates Python's packaging best practices and should be avoided.
To make your custom import hook be supported, you need to define a magic method __find__ to return the list of all modules.
For example:
class MyImportHook:
def __find__(self, name: str=None) -> list[str]:
"""
Return a list of all modules that are available to the import hook without import them.
If the "name" is provided, the method should return a list of all submodules that under the module named "name".
parameter name: The name of the module to find submodules for. If None, return all top modules.
"""
return []
The __find__ method should return a list of all modules that are available to the import hook without import them.
If the "name" is provided, the method should return a list of all submodules that under the module named "name". Or it needs to return all top modules if the "name" is None.
Credits
This package was created by [Locked-chess-official] and is maintained by [Locked-chess-official].
Project details
Release history Release notifications | RSS feed
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file friendly_module_not_found_error-0.3.0.tar.gz.
File metadata
- Download URL: friendly_module_not_found_error-0.3.0.tar.gz
- Upload date:
- Size: 10.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
056943587d24c8c76d9bcb8dd1455f041028ad8f8f5ff09fdefdea83379b3ac0
|
|
| MD5 |
36035c98778bce2bcf7d7c8233df5e1e
|
|
| BLAKE2b-256 |
9606a3c1260de2d96a8445abef541261dacdfa23d2b34819ee6f00cb35aed0f7
|
File details
Details for the file friendly_module_not_found_error-0.3.0-py3-none-any.whl.
File metadata
- Download URL: friendly_module_not_found_error-0.3.0-py3-none-any.whl
- Upload date:
- Size: 10.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cb6ab697e12ca156ae0fb9fefd11cdba9d45bef036451b2f369a5b5663cdac98
|
|
| MD5 |
e17374e7d8d725e1eea494a9d6735ac0
|
|
| BLAKE2b-256 |
2ed9d403c07136140a16d5f6d3238748316ccb11f034b622b984f958cbef460d
|