megfile.smart module
- class megfile.smart.SmartCacher(path: str, cache_path: str | None = None, mode: str = 'r')[source]
Bases:
FileCacher
- cache_path = None
- megfile.smart.register_copy_func(src_protocol: str, dst_protocol: str, copy_func: Callable | None = None) None [source]
Used to register copy func between protocols, and do not allow duplicate registration
- Parameters:
src_protocol – protocol name of source file, e.g. ‘s3’
dst_protocol – protocol name of destination file, e.g. ‘s3’
copy_func – copy func, its type is: Callable[[str, str, Optional[Callable[[int], None]], Optional[bool], Optional[bool]], None]
- megfile.smart.smart_abspath(path: str | BasePath | PathLike)[source]
Return the absolute path of given path
- Parameters:
path – Given path
- Returns:
Absolute path of given path
- megfile.smart.smart_access(path: str | BasePath | PathLike, mode: Access) bool [source]
Test if path has access permission described by mode
- Parameters:
path – Path to be tested
mode – Access mode(Access.READ, Access.WRITE, Access.BUCKETREAD, Access.BUCKETWRITE)
- Returns:
bool, if the path has read/write access.
- megfile.smart.smart_cache(path, cacher=<class 'megfile.smart.SmartCacher'>, **options)[source]
Return a path to Posixpath Interface
param path: Path to cache param s3_cacher: Cacher for s3 path param options: Optional arguments for s3_cacher
- megfile.smart.smart_combine_open(path_glob: str, mode: str = 'rb', open_func=<function smart_open>) CombineReader [source]
Open a unified reader that supports multi file reading.
- Parameters:
path_glob – A path may contain shell wildcard characters
mode – Mode to open file, supports ‘rb’
- Returns:
A
`CombineReader`
- megfile.smart.smart_concat(src_paths: List[str | BasePath | PathLike], dst_path: str | BasePath | PathLike) None [source]
Concatenate src_paths to dst_path
- Parameters:
src_paths – List of source paths
dst_path – Destination path
- megfile.smart.smart_copy(src_path: str | BasePath | PathLike, dst_path: str | BasePath | PathLike, callback: Callable[[int], None] | None = None, followlinks: bool = False, overwrite: bool = True) None [source]
Copy file from source path to destination path
Here are a few examples:
>>> from tqdm import tqdm >>> from megfile import smart_copy, smart_stat >>> class Bar: ... def __init__(self, total=10): ... self._bar = tqdm(total=10) ... ... def __call__(self, bytes_num): ... self._bar.update(bytes_num) ... >>> src_path = 'test.png' >>> dst_path = 'test1.png' >>> smart_copy( ... src_path, ... dst_path, ... callback=Bar(total=smart_stat(src_path).size), followlinks=False ... ) 856960it [00:00, 260592384.24it/s]
- Parameters:
src_path – Given source path
dst_path – Given destination path
callback – Called periodically during copy, and the input parameter is the data size (in bytes) of copy since the last call
followlinks – False if regard symlink as file, else True
overwrite – whether or not overwrite file when exists, default is True
- megfile.smart.smart_exists(path: str | BasePath | PathLike, followlinks: bool = False) bool [source]
Test if path or s3_url exists
- Parameters:
path – Path to be tested
- Returns:
True if path exists, else False
- megfile.smart.smart_getmd5(path: str | BasePath | PathLike, recalculate: bool = False)[source]
Get md5 value of file
param path: File path param recalculate: calculate md5 in real-time or not return s3 etag when path is s3
- megfile.smart.smart_getmtime(path: str | BasePath | PathLike) float [source]
Get last-modified time of the file on the given s3_url or file path (in Unix timestamp format).
If the path is an existent directory, return the latest modified time of all file in it. The mtime of empty directory is 1970-01-01 00:00:00
- Parameters:
path – Given path
- Returns:
Last-modified time
- Raises:
FileNotFoundError
- megfile.smart.smart_getsize(path: str | BasePath | PathLike) int [source]
Get file size on the given s3_url or file path (in bytes).
If the path in a directory, return the sum of all file size in it, including file in subdirectories (if exist).
The result excludes the size of directory itself. In other words, return 0 Byte on an empty directory path.
- Parameters:
path – Given path
- Returns:
File size
- Raises:
FileNotFoundError
- megfile.smart.smart_glob(pathname: str | BasePath | PathLike, recursive: bool = True, missing_ok: bool = True) List[str] [source]
Given pathname may contain shell wildcard characters, return path list in ascending alphabetical order, in which path matches glob pattern
- Parameters:
pathname – A path pattern may contain shell wildcard characters
recursive – If False, this function will not glob recursively
missing_ok – If False and target path doesn’t match any file, raise FileNotFoundError
- megfile.smart.smart_glob_stat(pathname: str | BasePath | PathLike, recursive: bool = True, missing_ok: bool = True) Iterator[FileEntry] [source]
Given pathname may contain shell wildcard characters, return a list contains tuples of path and file stat in ascending alphabetical order, in which path matches glob pattern
- Parameters:
pathname – A path pattern may contain shell wildcard characters
recursive – If False, this function will not glob recursively
missing_ok – If False and target path doesn’t match any file, raise FileNotFoundError
- megfile.smart.smart_iglob(pathname: str | BasePath | PathLike, recursive: bool = True, missing_ok: bool = True) Iterator[str] [source]
Given pathname may contain shell wildcard characters, return path iterator in ascending alphabetical order, in which path matches glob pattern
- Parameters:
pathname – A path pattern may contain shell wildcard characters
recursive – If False, this function will not glob recursively
missing_ok – If False and target path doesn’t match any file, raise FileNotFoundError
- megfile.smart.smart_isabs(path: str | BasePath | PathLike) bool [source]
Test whether a path is absolute
- Parameters:
path – Given path
- Returns:
True if a path is absolute, else False
- megfile.smart.smart_isdir(path: str | BasePath | PathLike, followlinks: bool = False) bool [source]
Test if a file path or an s3 url is directory
- Parameters:
path – Path to be tested
- Returns:
True if path is directory, else False
- megfile.smart.smart_isfile(path: str | BasePath | PathLike, followlinks: bool = False) bool [source]
Test if a file path or an s3 url is file
- Parameters:
path – Path to be tested
- Returns:
True if path is file, else False
- megfile.smart.smart_ismount(path: str | BasePath | PathLike) bool [source]
Test whether a path is a mount point
- Parameters:
path – Given path
- Returns:
True if a path is a mount point, else False
- megfile.smart.smart_listdir(path: str | BasePath | PathLike | None = None) List[str] [source]
Get all contents of given s3_url or file path. The result is in ascending alphabetical order.
- Parameters:
path – Given path
- Returns:
All contents of given s3_url or file path in ascending alphabetical order.
- Raises:
FileNotFoundError, NotADirectoryError
- megfile.smart.smart_load_content(path: str | BasePath | PathLike, start: int | None = None, stop: int | None = None) bytes [source]
Get specified file from [start, stop) in bytes
- Parameters:
path – Specified path
start – start index
stop – stop index
- Returns:
bytes content in range [start, stop)
- megfile.smart.smart_load_from(path: str | BasePath | PathLike) BinaryIO [source]
Read all content in binary on specified path and write into memory
User should close the BinaryIO manually
- Parameters:
path – Specified path
- Returns:
BinaryIO
- megfile.smart.smart_load_text(path: str | BasePath | PathLike) str [source]
Read content from path
param path: Path to be read
- megfile.smart.smart_makedirs(path: str | BasePath | PathLike, exist_ok: bool = False) None [source]
Create a directory if is on fs. If on s3, it actually check if target exists, and check if bucket has WRITE access
- Parameters:
path – Given path
missing_ok – if False and target directory not exists, raise FileNotFoundError
- Raises:
PermissionError, FileExistsError
- megfile.smart.smart_move(src_path: str | BasePath | PathLike, dst_path: str | BasePath | PathLike, overwrite: bool = True) None [source]
Move file/directory on s3 or fs. s3:// or s3://bucket is not allowed to move
- Parameters:
src_path – Given source path
dst_path – Given destination path
overwrite – whether or not overwrite file when exists
- megfile.smart.smart_open(path: str | ~megfile.pathlike.BasePath | ~os.PathLike, mode: str = 'r', s3_open_func: ~typing.Callable[[str, str], ~typing.BinaryIO] = <function s3_buffered_open>, encoding: str | None = None, errors: str | None = None, **options) IO [source]
Open a file on the path
Note
On fs, the difference between this function and
io.open
is that this function create directories automatically, instead of raising FileNotFoundErrorCurrently, supported protocols are:
s3: “s3://<bucket>/<key>”
http(s): http(s) url
stdio: “stdio://-”
FS file: Besides above mentioned protocols, other path are considered fs path
Here are a few examples:
>>> import cv2 >>> import numpy as np >>> raw = smart_open( ... 'https://ss2.bdstatic.com/70cFvnSh_Q1YnxGkpoWK1HF6hhy' ... '/it/u=2275743969,3715493841&fm=26&gp=0.jpg' ... ).read() >>> img = cv2.imdecode(np.frombuffer(raw, np.uint8), ... cv2.IMREAD_ANYDEPTH | cv2.IMREAD_COLOR)
- Parameters:
path – Given path
mode – Mode to open file, supports r’[rwa][tb]?+?’
s3_open_func – Function used to open s3_url. Require the function includes 2 necessary parameters, file path and mode
encoding – encoding is the name of the encoding used to decode or encode the file. This should only be used in text mode.
errors – errors is an optional string that specifies how encoding and decoding errors are to be handled—this cannot be used in binary mode.
- Returns:
File-Like object
- Raises:
FileNotFoundError, IsADirectoryError, ValueError
- megfile.smart.smart_path_join(path: str | BasePath | PathLike, *other_paths: str | BasePath | PathLike) str [source]
Concat 2 or more path to a complete path
- Parameters:
path – Given path
other_paths – Paths to be concatenated
- Returns:
Concatenated complete path
Note
For URI, the difference between this function and
os.path.join
is that this function ignores left side slash (which indicates absolute path) inother_paths
and will directly concat.e.g. os.path.join(‘s3://path’, ‘to’, ‘/file’) => ‘/file’, and smart_path_join(‘s3://path’, ‘to’, ‘/file’) => ‘/path/to/file’
But for fs path, this function behaves exactly like
os.path.join
e.g. smart_path_join(‘/path’, ‘to’, ‘/file’) => ‘/file’
- megfile.smart.smart_readlink(path: str | BasePath | PathLike) str | BasePath | PathLike [source]
Return a string representing the path to which the symbolic link points. :param path: Path to be read :returns: Return a string representing the path to which the symbolic link points.
- megfile.smart.smart_realpath(path: str | BasePath | PathLike)[source]
Return the real path of given path
- Parameters:
path – Given path
- Returns:
Real path of given path
- megfile.smart.smart_relpath(path: str | BasePath | PathLike, start=None)[source]
Return the relative path of given path
- Parameters:
path – Given path
start – Given start directory
- Returns:
Relative path from start
- megfile.smart.smart_remove(path: str | BasePath | PathLike, missing_ok: bool = False) None [source]
Remove the file or directory on s3 or fs, s3:// and s3://bucket are not permitted to remove
- Parameters:
path – Given path
missing_ok – if False and target file/directory not exists, raise FileNotFoundError
- Raises:
PermissionError, FileNotFoundError
- megfile.smart.smart_rename(src_path: str | BasePath | PathLike, dst_path: str | BasePath | PathLike, overwrite: bool = True) None [source]
Move file on s3 or fs. s3:// or s3://bucket is not allowed to move
- Parameters:
src_path – Given source path
dst_path – Given destination path
overwrite – whether or not overwrite file when exists
- megfile.smart.smart_save_as(file_object: BinaryIO, path: str | BasePath | PathLike) None [source]
Write the opened binary stream to specified path, but the stream won’t be closed
- Parameters:
file_object – Stream to be read
path – Specified target path
- megfile.smart.smart_save_content(path: str | BasePath | PathLike, content: bytes) None [source]
Save bytes content to specified path
param path: Path to save content
- megfile.smart.smart_save_text(path: str | BasePath | PathLike, text: str) None [source]
Save text to specified path
param path: Path to save text
- megfile.smart.smart_scan(path: str | BasePath | PathLike, missing_ok: bool = True, followlinks: bool = False) Iterator[str] [source]
Iteratively traverse only files in given directory, in alphabetical order. Every iteration on generator yields a path string.
If path is a file path, yields the file only If path is a non-existent path, return an empty generator If path is a bucket path, return all file paths in the bucket
- Parameters:
path – Given path
missing_ok – If False and there’s no file in the directory, raise FileNotFoundError
- Raises:
UnsupportedError
- Returns:
A file path generator
- megfile.smart.smart_scan_stat(path: str | BasePath | PathLike, missing_ok: bool = True, followlinks: bool = False) Iterator[FileEntry] [source]
Iteratively traverse only files in given directory, in alphabetical order. Every iteration on generator yields a tuple of path string and file stat
- Parameters:
path – Given path
missing_ok – If False and there’s no file in the directory, raise FileNotFoundError
- Raises:
UnsupportedError
- Returns:
A file path generator
- megfile.smart.smart_scandir(path: str | BasePath | PathLike | None = None) Iterator[FileEntry] [source]
Get all content of given s3_url or file path.
- Parameters:
path – Given path
- Returns:
An iterator contains all contents have prefix path
- Raises:
FileNotFoundError, NotADirectoryError
- megfile.smart.smart_stat(path: str | BasePath | PathLike, follow_symlinks=True) StatResult [source]
Get StatResult of s3_url or file path
- Parameters:
path – Given path
- Returns:
StatResult
- Raises:
FileNotFoundError
- megfile.smart.smart_symlink(src_path: str | BasePath | PathLike, dst_path: str | BasePath | PathLike) None [source]
Create a symbolic link pointing to src_path named path.
- Parameters:
src_path – Source path
dst_path – Destination path
- megfile.smart.smart_sync(src_path: str | ~megfile.pathlike.BasePath | ~os.PathLike, dst_path: str | ~megfile.pathlike.BasePath | ~os.PathLike, callback: ~typing.Callable[[str, int], None] | None = None, followlinks: bool = False, callback_after_copy_file: ~typing.Callable[[str, str], None] | None = None, src_file_stats: ~typing.Iterable[~megfile.pathlike.FileEntry] | None = None, map_func: ~typing.Callable[[~typing.Callable, ~typing.Iterable], ~typing.Any] = <class 'map'>, force: bool = False, overwrite: bool = True) None [source]
Sync file or directory
Note
When the parameter is file, this function bahaves like
smart_copy
.If file and directory of same name and same level, sync consider it’s file first
Here are a few examples:
>>> from tqdm import tqdm >>> from threading import Lock >>> from megfile import smart_sync, smart_stat, smart_glob >>> class Bar: ... def __init__(self, total_file): ... self._total_file = total_file ... self._bar = None ... self._now = None ... self._file_index = 0 ... self._lock = Lock() ... def __call__(self, path, num_bytes): ... with self._lock: ... if path != self._now: ... self._file_index += 1 ... print("copy file {}/{}:".format(self._file_index, ... self._total_file)) ... if self._bar: ... self._bar.close() ... self._bar = tqdm(total=smart_stat(path).size) ... self._now = path ... self._bar.update(num_bytes) >>> total_file = len(list(smart_glob('src_path'))) >>> smart_sync('src_path', 'dst_path', callback=Bar(total_file=total_file))
- Parameters:
src_path – Given source path
dst_path – Given destination path
callback – Called periodically during copy, and the input parameter is the data size (in bytes) of copy since the last call
followlinks – False if regard symlink as file, else True
callback_after_copy_file – Called after copy success, and the input parameter is src file path and dst file path
src_file_stats – If this parameter is not None, only this parameter’s files will be synced,and src_path is the root_path of these files used to calculate the path of the target file. This parameter is in order to reduce file traversal times.
map_func – A Callable func like map. You can use ThreadPoolExecutor.map, Pool.map and so on if you need concurrent capability. default is standard library map.
force – Sync file forcible, do not ignore same files, priority is higher than ‘overwrite’, default is False
overwrite – whether or not overwrite file when exists, default is True
- megfile.smart.smart_sync_with_progress(src_path, dst_path, callback: ~typing.Callable[[str, int], None] | None = None, followlinks: bool = False, map_func: ~typing.Callable[[~typing.Callable, ~typing.Iterable], ~typing.Iterator] = <class 'map'>, force: bool = False, overwrite: bool = True)[source]
Sync file or directory with progress bar
- Parameters:
src_path – Given source path
dst_path – Given destination path
callback – Called periodically during copy, and the input parameter is the data size (in bytes) of copy since the last call
followlinks – False if regard symlink as file, else True
callback_after_copy_file – Called after copy success, and the input parameter is src file path and dst file path
src_file_stats – If this parameter is not None, only this parameter’s files will be synced, and src_path is the root_path of these files used to calculate the path of the target file. This parameter is in order to reduce file traversal times.
map_func – A Callable func like map. You can use ThreadPoolExecutor.map, Pool.map and so on if you need concurrent capability. default is standard library map.
force – Sync file forcible, do not ignore same files, priority is higher than ‘overwrite’, default is False
overwrite – whether or not overwrite file when exists, default is True
- megfile.smart.smart_touch(path: str | BasePath | PathLike)[source]
Create a new file on path
param path: Path to create file
- megfile.smart.smart_unlink(path: str | BasePath | PathLike, missing_ok: bool = False) None [source]
Remove the file on s3 or fs
- Parameters:
path – Given path
missing_ok – if False and target file not exists, raise FileNotFoundError
- Raises:
PermissionError, FileNotFoundError, IsADirectoryError
- megfile.smart.smart_walk(path: str | BasePath | PathLike, followlinks: bool = False) Iterator[Tuple[str, List[str], List[str]]] [source]
Generate the file names in a directory tree by walking the tree top-down. For each directory in the tree rooted at directory path (including path itself), it yields a 3-tuple (root, dirs, files).
root: a string of current path
dirs: name list of subdirectories (excluding ‘.’ and ‘..’ if they exist) in ‘root’ The list is sorted by ascending alphabetical order
files: name list of non-directory files (link is regarded as file) in ‘root’. The list is sorted by ascending alphabetical order
If path not exists, return an empty generator If path is a file, return an empty generator If try to apply walk() on unsupported path, raise UnsupportedError
- Parameters:
path – Given path
- Raises:
UnsupportedError
- Returns:
A 3-tuple generator