importing a module by physical file path
Project description
Importing a module from physical file path.
examples
these files are existed, then..
$ tree
.
├── a
│ └── b
│ └── c
│ └── foo.py
└── main.py
4 directories, 3 files
a/b/c/foo.py
name = "foo"
_age = "*secret*"
from magicalimport import import_from_physical_path
# importing foo.py as the module named foo2
foo = import_from_physical_path("./a/b/c/foo.py", as_="foo2")
print(foo.name)
# cached in sys.modules, so it is ok.
import foo2
print(foo2.name)
here option
from magicalimport import import_from_physical_path
import_from_physical_path("bar.py", here="/tmp/foo", as_="bar")
star import
from magicalimport import import_from_physical_path
from magicalimport import expose_all_members
# something of like a `from foo import *`
expose_all_members(import_from_physical_path("./a/b/c/foo.py"))
print(name) # "foo"
# print(_age) # NameError.. because expose_all_members() doesn't expose the symbols started by "_"
# or
from magicalimport import expose_members
expose_members(import_from_physical_path("./a/b/c/foo.py"), members=["_age"])
print(_age) # "*secret*"
0.3
ns option in import_symbol
0.2.1
here option is supported
0.2
python2 support
0.1
first release
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
magicalimport-0.3.2.tar.gz
(3.0 kB
view hashes)
Built Distribution
Close
Hashes for magicalimport-0.3.2-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e9530c8ceeb6d47a94160d8f91e5b8738934b910b05f75f77b09fb571441d65e |
|
MD5 | 7e8fbba0fb6b5a9f51bcae9bb5559197 |
|
BLAKE2b-256 | 30a9d97c79a81a421a5e7638b96e4ab6b24a011ebc20dd7bc894fb8a5f86f650 |