This library is no longer maintained, you should instead use the official CLI client MEGAcmd:
Download it: https://mega.io/cmd#downloadapps
Learn how to use it: https://github.com/meganz/MEGAcmd/blob/master/UserGuide.md
Python library for the Mega.co.nz API, currently supporting:
- login
- uploading
- downloading
- deleting
- searching
- sharing
- renaming
- moving files
This is a work in progress, further functionality coming shortly.
For more detailed information see API_INFO.md
First, create an account with Mega .
Run the following command, or run setup from the latest github source.
pip install git+https://github.com/Eninspace/mega.py.git
from mega import Mega
mega = Mega()
m = mega.login(email, password)
# login using a temporary anonymous account
m = mega.login()
details = m.get_user()
balance = m.get_balance()
quota = m.get_quota()
# specify unit output kilo, mega, gig, else bytes will output
space = m.get_storage_space(kilo=True)
files = m.get_files()
file = m.upload('myfile.doc')
m.get_upload_link(file)
# see mega.py for destination and filename options
public_exported_web_link = m.export('myfile.doc')
public_exported_web_link = m.export('my_mega_folder/my_sub_folder_to_share')
# e.g. https://mega.nz/#F!WlVl1CbZ!M3wmhwZDENMNUJoBsdzFng
folder = m.find('my_mega_folder')
# Excludes results which are in the Trash folder (i.e. deleted)
folder = m.find('my_mega_folder', exclude_deleted=True)
folder = m.find('my_mega_folder')
m.upload('myfile.doc', folder[0])
file = m.find('myfile.doc')
m.download(file)
m.download_url('https://mega.co.nz/#!utYjgSTQ!OM4U3V5v_W4N5edSo0wolg1D5H0fwSrLD3oLnLuS9pc')
m.download(file, '/home/john-smith/Desktop')
# specify optional download filename (download_url() supports this also)
m.download(file, '/home/john-smith/Desktop', 'myfile.zip')
m.import_public_url('https://mega.co.nz/#!utYjgSTQ!OM4U3V5v_W4N5edSo0wolg1D5H0fwSrLD3oLnLuS9pc')
folder_node = m.find('Documents')[1]
m.import_public_url('https://mega.co.nz/#!utYjgSTQ!OM4U3V5v_W4N5edSo0wolg1D5H0fwSrLD3oLnLuS9pc', dest_node=folder_node)
m.create_folder('new_folder')
m.create_folder('new_folder/sub_folder/subsub_folder')
Returns a dict of folder node name and node_id, e.g.
{
'new_folder': 'qpFhAYwA',
'sub_folder': '2pdlmY4Z',
'subsub_folder': 'GgMFCKLZ'
}
file = m.find('myfile.doc')
m.rename(file, 'my_file.doc')
For paid priority support contact mega@odwyer.software.