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, id=None, img_id=None, ext='', pages=0, name_format='[%i][%a][%t]', **kwargs):
35 self.downloader = None
36 self.url = '%s/%d' % (DETAIL_URL, self.id)
37 self.info = DoujinshiInfo(**kwargs)
39 name_format = name_format.replace('%i', str(self.id))
40 name_format = name_format.replace('%a', self.info.artists)
41 name_format = name_format.replace('%t', self.name)
42 name_format = name_format.replace('%s', self.info.subtitle)
43 self.filename = format_filename(name_format)
47 ["Parodies", self.info.parodies],
48 ["Doujinshi", self.name],
49 ["Subtitle", self.info.subtitle],
50 ["Characters", self.info.characters],
51 ["Authors", self.info.artists],
52 ["Languages", self.info.languages],
53 ["Tags", self.info.tags],
55 ["Pages", self.pages],
60 return '<Doujinshi: {0}>'.format(self.name)
64 logger.info(u'Print doujinshi information of {0}\n{1}'.format(self.id, tabulate(self.table)))
68 logger.info('Starting to download doujinshi: %s' % self.name)
72 if len(self.ext) != self.pages:
73 logger.warning('Page count and ext count do not equal')
75 for i in range(1, min(self.pages, len(self.ext)) + 1):
76 download_queue.append('%s/%d/%d.%s' % (IMAGE_URL, int(self.img_id), i, self.ext[i-1]))
78 self.downloader.download(download_queue, self.filename)
81 for i in range(len(self.ext)):
82 download_queue.append('%s/%d/%d.%s' % (IMAGE_URL, int(self.img_id), i+1, EXT_MAP[self.ext[i]]))
86 logger.critical('Downloader has not been loaded')
89 if __name__ == '__main__':
90 test = Doujinshi(name='test nhentai doujinshi', id=1)
95 except Exception as e:
96 print('Exception: %s' % str(e))