home *** CD-ROM | disk | FTP | other *** search
/ Maximum CD 2011 January / maximum-cd-2011-01.iso / DiscContents / calibre-0.7.26.msi / file_4145 < prev    next >
Encoding:
Text File  |  2010-09-30  |  4.8 KB  |  91 lines

  1. __license__   = 'GPL v3'
  2. __copyright__ = '2010, Darko Miletic <darko.miletic at gmail.com>, Rogelio Dom├¡nguez <rogelio.dominguez@gmail.com>'
  3. '''
  4. www.jornada.unam.mx
  5. '''
  6.  
  7. import re
  8. from calibre import strftime
  9. from calibre.web.feeds.news import BasicNewsRecipe
  10.  
  11. class LaJornada_mx(BasicNewsRecipe):
  12.     title                 = 'La Jornada (Mexico)'
  13.     __author__            = 'Darko Miletic/Rogelio Dom├¡nguez'
  14.     description           = 'Noticias del diario mexicano La Jornada'
  15.     publisher             = 'DEMOS, Desarrollo de Medios, S.A. de C.V.'
  16.     category              = 'news, Mexico'
  17.     oldest_article        = 2
  18.     max_articles_per_feed = 200
  19.     no_stylesheets        = True
  20.     encoding              = 'utf8'
  21.     use_embedded_content  = False
  22.     language              = 'es'
  23.     remove_empty_feeds    = True
  24.     cover_url             = strftime("http://www.jornada.unam.mx/%Y/%m/%d/portada.pdf")
  25.     masthead_url          = 'http://www.jornada.unam.mx/v7.0/imagenes/la-jornada-trans.png'
  26.     publication_type      = 'newspaper'
  27.     extra_css             = """
  28.                                 body{font-family: "Times New Roman",serif }
  29.                                 .cabeza{font-size: xx-large; font-weight: bold }
  30.                                 .documentFirstHeading{font-size: xx-large; font-weight: bold }
  31.                                 .credito-articulo{font-variant: small-caps; font-weight: bold }
  32.                                 .foto{text-align: center}
  33.                                 .pie-foto{font-size: 0.9em}
  34.                                 .credito{font-weight: bold; margin-left: 1em}
  35.                                 .credito-autor{font-variant: small-caps; font-weight: bold }
  36.                                 .credito-titulo{text-align: right}
  37.                                 .hemero{text-align: right; font-size: 0.9em; margin-bottom: 0.5em } 
  38.                                 .loc{font-weight: bold} 
  39.                                 .carton{text-align: center}
  40.                                 .credit{font-weight: bold}
  41.                                 .text{margin-top: 1.4em}
  42.                                 p.inicial{display: inline; font-size: xx-large; font-weight: bold}
  43.                                 p.s-s{display: inline; text-indent: 0}
  44.                             """
  45.  
  46.     conversion_options = {
  47.                           'comment'   : description
  48.                         , 'tags'      : category
  49.                         , 'publisher' : publisher
  50.                         , 'language'  : language
  51.                         }
  52.  
  53.     preprocess_regexps = [
  54.                           (re.compile(  r'<div class="inicial">(.*)</div><p class="s-s">'
  55.                                        ,re.DOTALL|re.IGNORECASE)
  56.                                        ,lambda match: '<p class="inicial">' + match.group(1) + '</p><p class="s-s">')
  57.                          ]
  58.                         
  59.     keep_only_tags = [
  60.                          dict(name='div', attrs={'class':['documentContent','cabeza','sumarios','credito-articulo','text','carton']})
  61.                         ,dict(name='div', attrs={'id':'renderComments'})
  62.                      ]
  63.     remove_tags = [dict(name='div', attrs={'class':['buttonbar','comment-cont']})]
  64.  
  65.     feeds = [
  66.               (u'Opinion'             , u'http://www.jornada.unam.mx/rss/opinion.xml'      )
  67.              ,(u'Cartones'            , u'http://www.jornada.unam.mx/rss/cartones.xml'     )
  68.              ,(u'Politica'            , u'http://www.jornada.unam.mx/rss/politica.xml'     )
  69.              ,(u'Economia'            , u'http://www.jornada.unam.mx/rss/economia.xml'     )
  70.              ,(u'Mundo'               , u'http://www.jornada.unam.mx/rss/mundo.xml'        )
  71.              ,(u'Estados'             , u'http://www.jornada.unam.mx/rss/estados.xml'      )
  72.              ,(u'Capital'             , u'http://www.jornada.unam.mx/rss/capital.xml'      )
  73.              ,(u'Sociedad y justicia' , u'http://www.jornada.unam.mx/rss/sociedad.xml'     )
  74.              ,(u'Ciencias'            , u'http://www.jornada.unam.mx/rss/ciencias.xml'     )
  75.              ,(u'Cultura'             , u'http://www.jornada.unam.mx/rss/cultura.xml'      )
  76.              ,(u'Gastronomia'         , u'http://www.jornada.unam.mx/rss/gastronomia.xml'  )
  77.              ,(u'Espectaculos'        , u'http://www.jornada.unam.mx/rss/espectaculos.xml' )
  78.              ,(u'Deportes'            , u'http://www.jornada.unam.mx/rss/deportes.xml'     )
  79.              ,(u'Ultimas noticias'    , u'http://www.jornada.unam.mx/ultimas/news/RSS'     )
  80.             ]
  81.  
  82.     def preprocess_html(self, soup):
  83.         for item in soup.findAll(style=True):
  84.             del item['style']
  85.         return soup
  86.  
  87.     def get_article_url(self, article):
  88.         rurl = article.get('link',  None)
  89.         return rurl.rpartition('&partner=')[0]
  90.         
  91.