"ArticlePage object for presseurope" # -*- coding: utf-8 -*- # Copyright(C) 2012 Florent Fourcot # # This file is part of weboob. # # weboob is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # weboob is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Affero General Public License for more details. # # You should have received a copy of the GNU Affero General Public License # along with weboob. If not, see . from weboob.tools.capabilities.messages.genericArticle import GenericNewsPage,\ try_drop_tree, clean_relativ_urls class PresseuropPage(GenericNewsPage): "PresseuropPage object for presseurop" def on_loaded(self): self.main_div = self.document.getroot() self.element_title_selector = "title" self.element_author_selector = "div[id=content-author]>a" self.element_body_selector = "div.block, div.panel" def get_body(self): element_body = self.get_element_body() try_drop_tree(self.parser, element_body, "li.button-social") try_drop_tree(self.parser, element_body, "div.sharecount") clean_relativ_urls(element_body, "http://presseurop.eu") return self.parser.tostring(element_body) def get_title(self): title = GenericNewsPage.get_title(self) title = title.split('|')[0] return title def get_author(self): author = GenericNewsPage.get_author(self) try: source = self.document.getroot().xpath( "//span[@class='sourceinfo']/a")[0] source = source.text author = author + " | " + source return author except: return author class DailyTitlesPage(PresseuropPage): def on_loaded(self): self.main_div = self.document.getroot() self.element_title_selector = "title" self.element_author_selector = "div[id=content-author]>a" self.element_body_selector = "section.main" def get_body(self): element_body = self.get_element_body() try_drop_tree(self.parser, element_body, "li.button-social") try_drop_tree(self.parser, element_body, "aside.articlerelated") try_drop_tree(self.parser, element_body, "div.sharecount") clean_relativ_urls(element_body, "http://presseurop.eu") return self.parser.tostring(element_body) class DailySinglePage(PresseuropPage): def get_daily_date(self): plink = self.document.getroot().xpath("//p[@class='w200']") if len(plink) > 0: link = plink[0].xpath('a')[0] date = link.attrib['href'].split('/')[3] return date return None class CartoonPage(PresseuropPage): "CartoonPage object for presseurop" def on_loaded(self): self.main_div = self.document.getroot() self.element_title_selector = "title" self.element_author_selector = "div.profilecartoontext>p>a" self.element_body_selector = "div.panel"