3 from tabulate import tabulate
5 from nhentai.constant import DETAIL_URL, IMAGE_URL
6 from nhentai.logger import logger
7 from nhentai.utils import format_filename
17 class DoujinshiInfo(dict):
18 def __init__(self, **kwargs):
19 super(DoujinshiInfo, self).__init__(**kwargs)
21 def __getattr__(self, item):
23 return dict.__getitem__(self, item)
28 class Doujinshi(object):
29 def __init__(self, name=None, pretty_name=None, id=None, img_id=None,
30 ext='', pages=0, name_format='[%i][%a][%t]', **kwargs):
32 self.pretty_name = pretty_name
37 self.downloader = None
38 self.url = '%s/%d' % (DETAIL_URL, self.id)
39 self.info = DoujinshiInfo(**kwargs)
41 name_format = name_format.replace('%i', str(self.id))
42 name_format = name_format.replace('%a', self.info.artists)
43 name_format = name_format.replace('%t', self.name)
44 name_format = name_format.replace('%p', self.pretty_name)
45 name_format = name_format.replace('%s', self.info.subtitle)
46 self.filename = format_filename(name_format)
49 return '<Doujinshi: {0}>'.format(self.name)
53 ["Parodies", self.info.parodies],
54 ["Doujinshi", self.name],
55 ["Subtitle", self.info.subtitle],
56 ["Characters", self.info.characters],
57 ["Authors", self.info.artists],
58 ["Languages", self.info.languages],
59 ["Tags", self.info.tags],
61 ["Pages", self.pages],
63 logger.info(u'Print doujinshi information of {0}\n{1}'.format(self.id, tabulate(table)))
66 logger.info('Starting to download doujinshi: %s' % self.name)
69 if len(self.ext) != self.pages:
70 logger.warning('Page count and ext count do not equal')
72 for i in range(1, min(self.pages, len(self.ext)) + 1):
73 download_queue.append('%s/%d/%d.%s' % (IMAGE_URL, int(self.img_id), i, self.ext[i-1]))
75 self.downloader.download(download_queue, self.filename)
77 logger.critical('Downloader has not been loaded')
80 if __name__ == '__main__':
81 test = Doujinshi(name='test nhentai doujinshi', id=1)
86 except Exception as e:
87 print('Exception: %s' % str(e))