backup annotations too
This commit is contained in:
parent
9f56cff77b
commit
b3d7768839
2 changed files with 44 additions and 1 deletions
40
backup_annotations.py
Executable file
40
backup_annotations.py
Executable file
|
@ -0,0 +1,40 @@
|
||||||
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
|
import json
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
import unicodedata
|
||||||
|
|
||||||
|
import ox
|
||||||
|
import ox.api
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
if len(sys.argv) > 1:
|
||||||
|
target = sys.argv[1]
|
||||||
|
else:
|
||||||
|
target = os.path.join(os.path.dirname(os.path.abspath(__file__)), 'Films')
|
||||||
|
|
||||||
|
if not target.endswith('/'):
|
||||||
|
target += '/'
|
||||||
|
|
||||||
|
site = 'pandora.cinemusespace.com'
|
||||||
|
api = ox.api.signin('https://%s/api/' % site)
|
||||||
|
|
||||||
|
keep = []
|
||||||
|
r = api.find({'range': [0, 1000], 'keys': ['id']})
|
||||||
|
for i in r['data']['items']:
|
||||||
|
item = api.get(id=i['id'], keys=[])['data']
|
||||||
|
layers = api.get(id=i['id'], keys=['layers'])['data']
|
||||||
|
item['layers'] = layers['layers']
|
||||||
|
director = item.get('director', ['Unknown Director'])
|
||||||
|
path = os.path.join('; '.join(director), '%s' % (item['title']))
|
||||||
|
if 'year' in item:
|
||||||
|
path += ' (%s)' % item['year']
|
||||||
|
path = ox.decode_html(path)
|
||||||
|
path = os.path.join(target, path)
|
||||||
|
ox.makedirs(path)
|
||||||
|
path = os.path.join(path, 'annotations.json')
|
||||||
|
with open(path, 'w') as fd:
|
||||||
|
json.dump(item, fd, ensure_ascii=False, indent=4, sort_keys=True)
|
||||||
|
|
|
@ -37,6 +37,9 @@ if __name__ == '__main__':
|
||||||
path += ' (%s)' % item['year']
|
path += ' (%s)' % item['year']
|
||||||
path = ox.decode_html(path)
|
path = ox.decode_html(path)
|
||||||
prefix = ox.decode_html(item['title'])
|
prefix = ox.decode_html(item['title'])
|
||||||
|
|
||||||
|
keep.append(unicodedata.normalize('NFD', os.path.join(target, path, 'annotations.json')))
|
||||||
|
|
||||||
parts = []
|
parts = []
|
||||||
if len(item['streams']) == 1:
|
if len(item['streams']) == 1:
|
||||||
id = item['streams'][0]
|
id = item['streams'][0]
|
||||||
|
@ -60,7 +63,7 @@ if __name__ == '__main__':
|
||||||
os.unlink(abspath)
|
os.unlink(abspath)
|
||||||
if not os.path.exists(abspath):
|
if not os.path.exists(abspath):
|
||||||
url = 'https://%s/%s/download/source/%s' % (site, id, part)
|
url = 'https://%s/%s/download/source/%s' % (site, id, part)
|
||||||
print('downloading', abspath[len(target) + 1:])
|
print('downloading', abspath[len(target):])
|
||||||
api.save_url(url, abspath)
|
api.save_url(url, abspath)
|
||||||
keep.append(unicodedata.normalize('NFD', abspath))
|
keep.append(unicodedata.normalize('NFD', abspath))
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue