diff --git a/src/calibre/web/feeds/recipes/__init__.py b/src/calibre/web/feeds/recipes/__init__.py index 830a1b635d..0769a82c66 100644 --- a/src/calibre/web/feeds/recipes/__init__.py +++ b/src/calibre/web/feeds/recipes/__init__.py @@ -18,7 +18,7 @@ recipe_modules = [ 'nytimes_sub', 'security_watch', 'cyberpresse', 'st_petersburg_times', 'clarin', 'financial_times', 'heise', 'le_monde', 'harpers', 'science_aas', 'science_news', 'the_nation', 'lrb', 'harpers_full', 'liberation', - 'linux_magazine', 'telegraph_uk', 'utne', 'sciencedaily' + 'linux_magazine', 'telegraph_uk', 'utne', 'sciencedaily', 'forbes', ] import re, imp, inspect, time, os diff --git a/src/calibre/web/feeds/recipes/forbes.py b/src/calibre/web/feeds/recipes/forbes.py new file mode 100644 index 0000000000..9fa281fa09 --- /dev/null +++ b/src/calibre/web/feeds/recipes/forbes.py @@ -0,0 +1,37 @@ +from calibre.ebooks.BeautifulSoup import BeautifulSoup +from calibre.web.feeds.news import BasicNewsRecipe + +class Forbes(BasicNewsRecipe): + title = u'Forbes' + description = 'Business and Financial News' + __author__ = 'Darko Miletic' + oldest_article = 30 + max_articles_per_feed = 100 + no_stylesheets = True + html2lrf_options = ['--base-font-size', '10'] + + cover_url = u'http://www.forbes.com/media/current_covers/forbes_120_160.gif' + + feeds = [(u'Latest', u'http://www.forbes.com/news/index.xml'), + (u'Most Popular', u'http://www.forbes.com/feeds/popstories.xml'), + (u'Most Emailed', u'http://www.forbes.com/feeds/mostemailed.xml'), + (u'Faces', u'http://www.forbes.com/facesscan/index.xml'), + (u'Technology', u'http://www.forbes.com/technology/index.xml'), + (u'Personal Tech', u'http://www.forbes.com/personaltech/index.xml'), + (u'Wireless', u'http://www.forbes.com/wireless/index.xml'), + (u'Business', u'http://www.forbes.com/business/index.xml'), + (u'Sports Money', u'http://www.forbes.com/sportsmoney/index.xml'), + (u'Sports', u'http://www.forbes.com/forbeslife/sports/index.xml'), + (u'Vehicles', u'http://www.forbes.com/forbeslife/vehicles/index.xml'), + (u'Leadership', u'http://www.forbes.com/leadership/index.xml'), + (u'Careers', u'http://www.forbes.com/leadership/careers/index.xml'), + (u'Compensation', u'http://www.forbes.com/leadership/compensation/index.xml'), + (u'Managing', u'http://www.forbes.com/leadership/managing/index.xml')] + + def print_version(self, url): + raw = self.browser.open(url).read() + soup = BeautifulSoup(raw.decode('latin1', 'replace')) + print_link = soup.find('a', {'onclick':"s_linkTrackVars='prop18';s_linkType='o';s_linkName='Print';if(typeof(globalPageName)!='undefined')s_prop18=globalPageName;s_lnk=s_co(this);s_gs(s_account);"}) + if print_link is None: + return '' + return 'http://www.forbes.com' + print_link['href'] \ No newline at end of file