- class ResourceReader?
Superseded by TraversableResources
An abstract base class to provide the ability to read resources.
From the perspective of this ABC, a resource is a binary artifact that is shipped within a package. Typically this is something like a data file that lives next to the
__init__.py
file of the package. The purpose of this class is to help abstract out the accessing of such data files so that it does not matter if the package and its data file(s) are stored in a e.g. zip file versus on the file system.For any of methods of this class, a resource argument is expected to be a path-like object which represents conceptually just a file name. This means that no subdirectory paths should be included in the resource argument. This is because the location of the package the reader is for, acts as the "directory". Hence the metaphor for directories and file names is packages and resources, respectively. This is also why instances of this class are expected to directly correlate to a specific package (instead of potentially representing multiple packages or a module).
Loaders that wish to support resource reading are expected to provide a method called
get_resource_reader(fullname)
which returns an object implementing this ABC's interface. If the module specified by fullname is not a package, this method should returnNone
. An object compatible with this ABC should only be returned when the specified module is a package.3.7 新版功能.
- abstractmethod open_resource(resource)?
Returns an opened, file-like object for binary reading of the resource.
If the resource cannot be found,
FileNotFoundError
is raised.
- abstractmethod resource_path(resource)?
Returns the file system path to the resource.
If the resource does not concretely exist on the file system, raise
FileNotFoundError
.
- abstractmethod is_resource(name)?
Returns
True
if the named name is considered a resource.FileNotFoundError
is raised if name does not exist.
- abstractmethod contents()?
Returns an iterable of strings over the contents of the package. Do note that it is not required that all names returned by the iterator be actual resources, e.g. it is acceptable to return names for which
is_resource()
would be false.Allowing non-resource names to be returned is to allow for situations where how a package and its resources are stored are known a priori and the non-resource names would be useful. For instance, returning subdirectory names is allowed so that when it is known that the package and resources are stored on the file system then those subdirectory names can be used directly.
The abstract method returns an iterable of no items.
- class ResourceLoader?
An abstract base class for a loader which implements the optional PEP 302 protocol for loading arbitrary resources from the storage back-end.
3.7 版后已移除: This ABC is deprecated in favour of supporting resource loading through
importlib.abc.ResourceReader
.- abstractmethod get_data(path)?
An abstract method to return the bytes for the data located at path. Loaders that have a file-like storage back-end that allows storing arbitrary data can implement this abstract method to give direct access to the data stored.
OSError
is to be raised if the path cannot be found. The path is expected to be constructed using a module's__file__
attribute or an item from a package's__path__
.在 3.4 版更改: Raises
OSError
instead ofNotImplementedError
.
- class InspectLoader?
An abstract base class for a loader which implements the optional PEP 302 protocol for loaders that inspect modules.
- get_code(fullname)?
Return the code object for a module, or
None
if the module does not have a code object (as would be the case, for example, for a built-in module). Raise anImportError
if loader cannot find the requested module.備注
While the method has a default implementation, it is suggested that it be overridden if possible for performance.
在 3.4 版更改: No longer abstract and a concrete implementation is provided.
- abstractmethod get_source(fullname)?
An abstract method to return the source of a module. It is returned as a text string using universal newlines, translating all recognized line separators into
'\n'
characters. ReturnsNone
if no source is available (e.g. a built-in module). RaisesImportError
if the loader cannot find the module specified.在 3.4 版更改: Raises
ImportError
instead ofNotImplementedError
.
- is_package(fullname)?
An optional method to return a true value if the module is a package, a false value otherwise.
ImportError
is raised if the loader cannot find the module.在 3.4 版更改: Raises
ImportError
instead ofNotImplementedError
.
- static source_to_code(data, path='<string>')?
Create a code object from Python source.
The data argument can be whatever the
compile()
function supports (i.e. string or bytes). The path argument should be the "path" to where the source code originated from, which can be an abstract concept (e.g. location in a zip file).With the subsequent code object one can execute it in a module by running
exec(code, module.__dict__)
.3.4 新版功能.
在 3.5 版更改: Made the method static.
- exec_module(module)?
Implementation of
Loader.exec_module()
.3.4 新版功能.
- load_module(fullname)?
Implementation of
Loader.load_module()
.3.4 版后已移除: use
exec_module()
instead.
- class ExecutionLoader?
An abstract base class which inherits from
InspectLoader
that, when implemented, helps a module to be executed as a script. The ABC represents an optional PEP 302 protocol.- abstractmethod get_filename(fullname)?
An abstract method that is to return the value of
__file__
for the specified module. If no path is available,ImportError
is raised.If source code is available, then the method should return the path to the source file, regardless of whether a bytecode was used to load the module.
在 3.4 版更改: Raises
ImportError
instead ofNotImplementedError
.
- class FileLoader(fullname, path)?
An abstract base class which inherits from
ResourceLoader
andExecutionLoader
, providing concrete implementations ofResourceLoader.get_data()
andExecutionLoader.get_filename()
.The fullname argument is a fully resolved name of the module the loader is to handle. The path argument is the path to the file for the module.
3.3 新版功能.
- name?
The name of the module the loader can handle.
- path?
Path to the file of the module.
- load_module(fullname)?
Calls super's
load_module()
.3.4 版后已移除: Use
Loader.exec_module()
instead.
- abstractmethod get_data(path)?
Reads path as a binary file and returns the bytes from it.
- class SourceLoader?
An abstract base class for implementing source (and optionally bytecode) file loading. The class inherits from both
ResourceLoader
andExecutionLoader
, requiring the implementation of:ExecutionLoader.get_filename()
Should only return the path to the source file; sourceless loading is not supported.
The abstract methods defined by this class are to add optional bytecode file support. Not implementing these optional methods (or causing them to raise
NotImplementedError
) causes the loader to only work with source code. Implementing the methods allows the loader to work with source and bytecode files; it does not allow for sourceless loading where only bytecode is provided. Bytecode files are an optimization to speed up loading by removing the parsing step of Python's compiler, and so no bytecode-specific API is exposed.- path_stats(path)?
Optional abstract method which returns a
dict
containing metadata about the specified path. Supported dictionary keys are:'mtime'
(mandatory): an integer or floating-point number representing the modification time of the source code;'size'
(optional): the size in bytes of the source code.
Any other keys in the dictionary are ignored, to allow for future extensions. If the path cannot be handled,
OSError
is raised.3.3 新版功能.
在 3.4 版更改: Raise
OSError
instead ofNotImplementedError
.
- path_mtime(path)?
Optional abstract method which returns the modification time for the specified path.
3.3 版后已移除: This method is deprecated in favour of
path_stats()
. You don't have to implement it, but it is still available for compatibility purposes. RaiseOSError
if the path cannot be handled.在 3.4 版更改: Raise
OSError
instead ofNotImplementedError
.
- set_data(path, data)?
Optional abstract method which writes the specified bytes to a file path. Any intermediate directories which do not exist are to be created automatically.
When writing to the path fails because the path is read-only (
errno.EACCES
/PermissionError
), do not propagate the exception.在 3.4 版更改: No longer raises
NotImplementedError
when called.
- get_code(fullname)?
Concrete implementation of
InspectLoader.get_code()
.
- exec_module(module)?
Concrete implementation of
Loader.exec_module()
.3.4 新版功能.
- load_module(fullname)?
Concrete implementation of
Loader.load_module()
.3.4 版后已移除: Use
exec_module()
instead.
- get_source(fullname)?
Concrete implementation of
InspectLoader.get_source()
.
- is_package(fullname)?
Concrete implementation of
InspectLoader.is_package()
. A module is determined to be a package if its file path (as provided byExecutionLoader.get_filename()
) is a file named__init__
when the file extension is removed and the module name itself does not end in__init__
.
- class Traversable?
An object with a subset of pathlib.Path methods suitable for traversing directories and opening files.
3.9 新版功能.
- name?
Abstract. The base name of this object without any parent references.
- abstractmethod iterdir()?
Yield Traversable objects in self.
- abstractmethod is_dir()?
Return True if self is a directory.
- abstractmethod is_file()?
Return True if self is a file.
- abstractmethod joinpath(child)?
Return Traversable child in self.
- abstractmethod __truediv__(child)?
Return Traversable child in self.
- abstractmethod open(mode='r', *args, **kwargs)?
mode may be 'r' or 'rb' to open as text or binary. Return a handle suitable for reading (same as
pathlib.Path.open
).When opening as text, accepts encoding parameters such as those accepted by
io.TextIOWrapper
.
- read_bytes()?
Read contents of self as bytes.
- read_text(encoding=None)?
Read contents of self as text.
- class TraversableResources?
An abstract base class for resource readers capable of serving the
importlib.resources.files()
interface. Subclassesimportlib.abc.ResourceReader
and provides concrete implementations of theimportlib.abc.ResourceReader
's abstract methods. Therefore, any loader supplyingimportlib.abc.TraversableReader
also supplies ResourceReader.Loaders that wish to support resource reading are expected to implement this interface.
3.9 新版功能.
- abstractmethod files()?
Returns a
importlib.abc.Traversable
object for the loaded package.