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
16 class DoujinshiInfo(dict):
17 def __init__(self, **kwargs):
18 super(DoujinshiInfo, self).__init__(**kwargs)
20 def __getattr__(self, item):
22 return dict.__getitem__(self, item)
27 class Doujinshi(object):
28 def __init__(self, name=None, pretty_name=None, id=None, img_id=None,
29 ext='', pages=0, name_format='[%i][%a][%t]', **kwargs):
31 self.pretty_name = pretty_name
36 self.downloader = None
37 self.url = '%s/%d' % (DETAIL_URL, self.id)
38 self.info = DoujinshiInfo(**kwargs)
40 name_format = name_format.replace('%i', str(self.id))
41 name_format = name_format.replace('%a', self.info.artists)
42 name_format = name_format.replace('%t', self.name)
43 name_format = name_format.replace('%p', self.pretty_name)
44 name_format = name_format.replace('%s', self.info.subtitle)
45 self.filename = format_filename(name_format)
48 ["Parodies", self.info.parodies],
49 ["Doujinshi", self.name],
50 ["Subtitle", self.info.subtitle],
51 ["Characters", self.info.characters],
52 ["Authors", self.info.artists],
53 ["Languages", self.info.languages],
54 ["Tags", self.info.tags],
56 ["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)))
67 logger.info('Starting to download doujinshi: %s' % self.name)
70 if len(self.ext) != self.pages:
71 logger.warning('Page count and ext count do not equal')
73 for i in range(1, min(self.pages, len(self.ext)) + 1):
74 download_queue.append('%s/%d/%d.%s' % (IMAGE_URL, int(self.img_id), i, self.ext[i - 1]))
76 self.downloader.download(download_queue, self.filename)
78 logger.critical('Downloader has not been loaded')
81 if __name__ == '__main__':
82 test = Doujinshi(name='test nhentai doujinshi', id=1)
87 except Exception as e:
88 print('Exception: %s' % str(e))