megfile.http_path module
-
class
megfile.http_path.HttpPath(path: Union[str, os.PathLike], *other_paths: Union[str, os.PathLike])[source] Bases:
megfile.pathlike.URIPath-
exists(followlinks: bool = False) → bool[source] Test if http path exists
- Parameters
followlinks (bool, optional) – ignore this parameter, just for compatibility
- Returns
return True if exists
- Return type
bool
-
getmtime(follow_symlinks: bool = False) → float[source] Get Last-Modified time of the http request on the given http_url path.
If http response header don’t support Last-Modified, will return None
- Parameters
follow_symlinks – Ignore this parameter, just for compatibility
- Returns
Last-Modified time (in Unix timestamp format)
- Raises
HttpPermissionError, HttpFileNotFoundError
-
getsize(follow_symlinks: bool = False) → int[source] Get file size on the given http_url path.
If http response header don’t support Content-Length, will return None
- Parameters
follow_symlinks – Ignore this parameter, just for compatibility
- Returns
File size (in bytes)
- Raises
HttpPermissionError, HttpFileNotFoundError
-
open(mode: str = 'rb', *, max_concurrency: Optional[int] = None, max_buffer_size: int = 134217728, forward_ratio: Optional[float] = None, block_size: int = 8388608, **kwargs) → Union[_io.BufferedReader, megfile.lib.http_prefetch_reader.HttpPrefetchReader][source] Open a BytesIO to read binary data of given http(s) url
Note
Essentially, it reads data of http(s) url to memory by requests, and then return BytesIO to user.
- Parameters
mode – Only supports ‘rb’ mode now
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.
max_concurrency – Max download thread number, None by default
max_buffer_size – Max cached buffer size in memory, 128MB by default
block_size – Size of single block, 8MB by default. Each block will be uploaded or downloaded by single thread.
- Returns
BytesIO initialized with http(s) data
-
protocol= 'http'
-
stat(follow_symlinks=True) → megfile.pathlike.StatResult[source] Get StatResult of http_url response, including size and mtime, referring to http_getsize and http_getmtime
- Parameters
follow_symlinks – Ignore this parameter, just for compatibility
- Returns
StatResult
- Raises
HttpPermissionError, HttpFileNotFoundError
-
-
class
megfile.http_path.HttpsPath(path: Union[str, os.PathLike], *other_paths: Union[str, os.PathLike])[source] Bases:
megfile.http_path.HttpPath-
protocol= 'https'
-