Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pgp/mega.py
Python library for the https://mega.nz/ API.
https://github.com/pgp/mega.py
Last synced: 3 months ago
JSON representation
Python library for the https://mega.nz/ API.
- Host: GitHub
- URL: https://github.com/pgp/mega.py
- Owner: pgp
- License: apache-2.0
- Fork: true (odwyersoftware/mega.py)
- Created: 2022-01-18T15:54:17.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2024-02-13T07:54:04.000Z (9 months ago)
- Last Synced: 2024-07-20T02:28:27.871Z (4 months ago)
- Language: Python
- Homepage: https://github.com/odwyersoftware/mega.py
- Size: 7.39 MB
- Stars: 11
- Watchers: 2
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: HISTORY.md
- License: LICENSE
Awesome Lists containing this project
README
Mega.py
=======Python library for the [Mega.nz](https://mega.nz)
API, currently supporting:- login
- uploading
- downloading
- deleting
- searching
- sharing
- renaming
- moving filesThis is a work in progress, further functionality coming shortly.
For more detailed information see API\_INFO.md
How To Use
----------### Create a Mega account
For downloading links, no account is needed. To use upload capabilities, [create an account with Mega](https://mega.nz) .
### Install mega.py package
Clone the repository, and then run:
```sh
cd mega.py
pip install .
```### Import mega.py
```python
from mega import Mega
```### Create an instance of Mega.py
```python
mega = Mega()
```### Login to Mega
```python
m = mega.login(email, password)
# login using a temporary anonymous account
m = mega.login()
```### Get user details
```python
details = m.get_user()
```### Get account balance (Pro accounts only)
```python
balance = m.get_balance()
```### Get account disk quota
```python
quota = m.get_quota()
```### Get account storage space
```python
# specify unit output kilo, mega, gig, else bytes will output
space = m.get_storage_space(kilo=True)
```### Get account files
```python
files = m.get_files()
```### Upload a file, and get its public link
```python
file = m.upload('myfile.doc')
m.get_upload_link(file)
# see mega.py for destination and filename options
```### Export a file or folder
```python
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
```### Find a file or folder
```python
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)
```### Upload a file to a destination folder
```python
folder = m.find('my_mega_folder')
m.upload('myfile.doc', folder[0])
```### Download a file from URL or file obj, optionally specify destination folder
```python
file = m.find('myfile.doc')
m.download(file)
m.download_url('https://mega.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')
```### Import a file from URL, optionally specify destination folder
```python
m.import_public_url('https://mega.nz/#!utYjgSTQ!OM4U3V5v_W4N5edSo0wolg1D5H0fwSrLD3oLnLuS9pc')
folder_node = m.find('Documents')[1]
m.import_public_url('https://mega.nz/#!utYjgSTQ!OM4U3V5v_W4N5edSo0wolg1D5H0fwSrLD3oLnLuS9pc', dest_node=folder_node)
```### Create a folder
```python
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.
```python
{
'new_folder': 'qpFhAYwA',
'sub_folder': '2pdlmY4Z',
'subsub_folder': 'GgMFCKLZ'
}
```### Rename a file or a folder
```python
file = m.find('myfile.doc')
m.rename(file, 'my_file.doc')
```