megfile
provides a silky operation experience with different backends (currently including local file system and OSS), which enable you to focus more on the logic of your own project instead of the question of "Which backend is used for this file?"
megfile
provides:
- Almost unified file system operation experience. Target path can be easily moved from local file system to OSS.
- Complete boundary case handling. Even the most difficult (or even you can't even think of) boundary conditions,
megfile
can help you easily handle it. - Perfect type hints and built-in documentation. You can enjoy the IDE's auto-completion and static checking.
- Semantic version and upgrade guide, which allows you enjoy the latest features easily.
megfile
's advantages are:
smart_open
can open resources that use various protocols, including fs, s3, http(s) and stdio. Especially, reader / writer of s3 inmegfile
is implemented with multi-thread, which is faster than known competitors.smart_glob
is available on s3. And it supports zsh extended pattern syntax of[]
, e.g.s3://bucket/video.{mp4,avi}
.- All-inclusive functions like
smart_exists
/smart_stat
/smart_sync
. If you don't find the functions you want, submit an issue. - Compatible with
pathlib.Path
interface, referring toS3Path
andSmartPath
.
Here's an example of writing a file to OSS, syncing to local, reading and finally deleting it.
from megfile import smart_open, smart_exists, smart_sync, smart_remove, smart_glob
from megfile.smart_path import SmartPath
with smart_open('s3://playground/megfile-test', 'w') as f:
f.write('megfile is not silver bullet')
assert smart_exists('s3://playground/megfile-test')
smart_sync('s3://playground/megfile-test', '/tmp/local-tmp/tmp-test')
with smart_open('/tmp/local-tmp/tmp-test', 'rb') as f:
result = f.read(7)
assert result == b'megfile'
smart_remove('/tmp/local-tmp/tmp-test')
assert smart_exists('/tmp/local-tmp/tmp-test') is False
smart_glob('s3://playground/video-?.{mp4,avi}')
# SmartPath Interface
path = SmartPath('s3://playground/megfile-test')
if path.exists():
with path.open() as f:
result = f.read(7)
assert result == b'megfile'
pip3 install megfile
You can specify megfile version as well
pip3 install "megfile~=0.0"
megfile can be installed from source
git clone git@github.com:megvii-research/megfile.git
cd megfile
pip3 install -U .
git clone git@github.com:megvii-research/megfile.git
cd megfile
sudo apt install libgl1-mesa-glx libfuse-dev fuse
pip3 install -r requirements.txt -r requirements-dev.txt
-
We welcome everyone to contribute code to the
megfile
project, but the contributed code needs to meet the following conditions as much as possible:You can submit code even if the code doesn't meet conditions. The project members will evaluate and assist you in making code changes
-
Code format: Your code needs to pass code format check.
megfile
usesyapf
as lint tool and the version is locked at 0.27.0. The version lock may be removed in the future -
Static check: Your code needs complete type hint.
megfile
usespytype
as static check tool. Ifpytype
failed in static check, use# pytype: disable=XXX
to disable the error and please tell us why you disable it.Note : Because
pytype
doesn't support variable type annation, the variable type hint format introduced by py36 cannot be used.i.e.
variable: int
is invalid, replace it withvariable # type: int
-
Test: Your code needs complete unit test coverage.
megfile
usespyfakefs
andmoto
as local file system and OSS virtual environment in unit tests. The newly added code should have a complete unit test to ensure the correctness
-
-
You can help to improve
megfile
in many ways:- Write code.
- Improve documentation.
- Report or investigate bugs and issues.
- If you find any problem or have any improving suggestion, submit a new issuse as well. We will reply as soon as possible and evaluate whether to adopt.
- Review pull requests.
- Star
megfile
repo. - Recommend
megfile
to your friends. - Any other form of contribution is welcomed.