# coding: utf-8
-from __future__ import print_function
+from __future__ import print_function, unicode_literals
from tabulate import tabulate
-from builtins import range
+from future.builtins import range
from nhentai.constant import DETAIL_URL, IMAGE_URL
from nhentai.logger import logger
+from nhentai.utils import format_filename
+
+
+EXT_MAP = {
+ 'j': 'jpg',
+ 'p': 'png',
+ 'g': 'gif',
+}
class DoujinshiInfo(dict):
class Doujinshi(object):
- def __init__(self, name=None, id=None, img_id=None, ext='jpg', pages=0, **kwargs):
+ def __init__(self, name=None, id=None, img_id=None, ext='', pages=0, **kwargs):
self.name = name
self.id = id
self.img_id = img_id
self.downloader = None
self.url = '%s/%d' % (DETAIL_URL, self.id)
self.info = DoujinshiInfo(**kwargs)
+ self.filename = format_filename('[%s][%s][%s]' % (self.id, self.info.artist, self.name))
def __repr__(self):
return '<Doujinshi: {0}>'.format(self.name)
table = [
["Doujinshi", self.name],
["Subtitle", self.info.subtitle],
- ["Characters", self.info.characters],
- ["Authors", self.info.artists],
+ ["Characters", self.info.character],
+ ["Authors", self.info.artist],
["Language", self.info.language],
- ["Tags", self.info.tags],
+ ["Tags", ', '.join(self.info.tag.keys())],
["URL", self.url],
["Pages", self.pages],
]
- logger.info(u'Print doujinshi information\n{0}'.format(tabulate(table)))
+ logger.info(u'Print doujinshi information of {0}\n{1}'.format(self.id, tabulate(table)))
def download(self):
- logger.info('Start download doujinshi: %s' % self.name)
+ logger.info('Starting to download doujinshi: %s' % self.name)
if self.downloader:
download_queue = []
- for i in range(1, self.pages + 1):
- download_queue.append('%s/%d/%d.%s' % (IMAGE_URL, int(self.img_id), i, self.ext))
- self.downloader.download(download_queue, self.id)
+
+ if len(self.ext) != self.pages:
+ logger.warning('Page count and ext count do not equal')
+
+ for i in range(1, min(self.pages, len(self.ext)) + 1):
+ download_queue.append('%s/%d/%d.%s' % (IMAGE_URL, int(self.img_id), i, self.ext[i-1]))
+
+ self.downloader.download(download_queue, self.filename)
+
+ '''
+ for i in range(len(self.ext)):
+ download_queue.append('%s/%d/%d.%s' % (IMAGE_URL, int(self.img_id), i+1, EXT_MAP[self.ext[i]]))
+ '''
+
else:
- logger.critical('Downloader has not be loaded')
+ logger.critical('Downloader has not been loaded')
if __name__ == '__main__':