diff --git a/gallery_dl/extractor/mangapanda.py b/gallery_dl/extractor/mangapanda.py index 56cb1ce0..9f12f557 100644 --- a/gallery_dl/extractor/mangapanda.py +++ b/gallery_dl/extractor/mangapanda.py @@ -19,9 +19,10 @@ class MangapandaBase(): class MangapandaMangaExtractor(MangapandaBase, MangareaderMangaExtractor): """Extractor for manga from mangapanda.com""" - pattern = [r"(?:https?://)?((?:www\.)?mangapanda\.com/[^/]+)$"] + pattern = [r"(?:https?://)?((?:www\.)?mangapanda\.com/[^/]+)/?$"] test = [("http://www.mangapanda.com/mushishi", { "url": "50a1ba730b85426b904da256c80f68ba6a8a2566", + "keyword": "031b3ea085921c552de017ecbb9b906e462229c9", })] @@ -35,5 +36,5 @@ class MangapandaChapterExtractor(MangapandaBase, MangareaderChapterExtractor): ] test = [("http://www.mangapanda.com/red-storm/2", { "url": "4bf4ddf6c50105ec8a37675495ab80c46608275d", - "keyword": "16c881a09f5cf0f2c1c374665b667d1f26b20c22", + "keyword": "367d2694b49cc7cac82d68530d7d467a62453502", })] diff --git a/gallery_dl/extractor/mangareader.py b/gallery_dl/extractor/mangareader.py index bc1f56cb..ce669439 100644 --- a/gallery_dl/extractor/mangareader.py +++ b/gallery_dl/extractor/mangareader.py @@ -19,19 +19,43 @@ class MangareaderBase(): filename_fmt = "{manga}_c{chapter:>03}_{page:>03}.{extension}" root = "http://www.mangareader.net" + @staticmethod + def _parse_page(page, data): + text.extract_all(page, ( + ("manga" , '

', '

'), + ("release", '>Year of Release:\n', ''), + ('author' , '>Author:\n', ''), + ('artist' , '>Artist:\n', ''), + ), values=data) + data["manga"] = data["manga"].strip() + data["author"] = text.unescape(data["author"]) + data["artist"] = text.unescape(data["artist"]) + class MangareaderMangaExtractor(MangareaderBase, MangaExtractor): """Extractor for manga from mangareader.net""" - pattern = [r"(?:https?://)?((?:www\.)?mangareader\.net/[^/]+)$"] + pattern = [r"(?:https?://)?((?:www\.)?mangareader\.net/[^/]+)/?$"] reverse = False test = [("http://www.mangareader.net/mushishi", { "url": "249042420b67a07b32e7f6be4c7410b6d810b808", + "keyword": "031b3ea085921c552de017ecbb9b906e462229c9", })] - def chapter_paths(self, page): + def chapters(self, page): + results = [] + data = {"lang": "en", "language": "English"} + self._parse_page(page, data) + needle = '
\n') - return text.extract_iter(page, needle, '"', pos) + pos = page.index('
') + while True: + url, pos = text.extract(page, needle, '"', pos) + if not url: + return results + data["title"], pos = text.extract(page, ' : ', '', pos) + data["date"] , pos = text.extract(page, '', '', pos) + data["chapter"] = int(url.rpartition("/")[2]) + results.append((self.root + url, data.copy())) class MangareaderChapterExtractor(MangareaderBase, AsynchronousExtractor): @@ -45,7 +69,7 @@ class MangareaderChapterExtractor(MangareaderBase, AsynchronousExtractor): test = [(("http://www.mangareader.net/" "karate-shoukoushi-kohinata-minoru/11"), { "url": "84ffaab4c027ef9022695c53163c3aeabd07ca58", - "keyword": "05ef372e80257726166f78625cb78a09e6d9b1d1", + "keyword": "2038e6a780a0028eee0067985b55debb1d4a6aab", })] def __init__(self, match): @@ -57,10 +81,9 @@ class MangareaderChapterExtractor(MangareaderBase, AsynchronousExtractor): data = self.get_job_metadata(page) yield Message.Version, 1 yield Message.Directory, data - for i in range(1, int(data["count"])+1): + for data["page"] in range(1, data["count"]+1): next_url, image_url, image_data = self.get_page_metadata(page) image_data.update(data) - image_data["page"] = i yield Message.Url, image_url, image_data if next_url: page = self.request(next_url).text @@ -69,30 +92,18 @@ class MangareaderChapterExtractor(MangareaderBase, AsynchronousExtractor): """Collect metadata for extractor-job""" page = self.request(self.root + self.url_title).text data = { - "chapter": self.chapter, + "chapter": int(self.chapter), "lang": "en", "language": "English", } - data, _ = text.extract_all(page, ( - (None, 'Name:', ''), - ("manga", '

', '

'), - (None, 'Year of Release:', ''), - ('release', '', ''), - (None, 'Author:', ''), - ('author', '', ''), - (None, 'Artist:', ''), - ('artist', '', ''), - (None, '
', ''), + self._parse_page(page, data) + text.extract_all(page, ( ('title', ' ' + self.chapter + ' : ', ''), ('date', '', ''), - ), values=data) - data, _ = text.extract_all(chapter_page, ( - (None, ' of ', '<')[0] + ) return data def get_page_metadata(self, page): @@ -112,6 +123,6 @@ class MangareaderChapterExtractor(MangareaderBase, AsynchronousExtractor): height, pos = extr(page, ' height="', '"', pos) image, pos = extr(page, ' src="', '"', pos) return self.root + url, image, text.nameext_from_url(image, { - "width": width, - "height": height, + "width": int(width), + "height": int(height), })