Exemplo n.º 1
0
 def construct(self, req, pages=1):
     htmls = req.request(self.url(), pages=pages)
     self.title = str(
         requestor.BeautifulSoup(htmls[0],
                                 'html.parser').find('title').text)
     for html in htmls:
         p1 = requestor.BeautifulSoup(html, 'html.parser')
         for match in p1.select(Section().selector()):
             section = Section()
             section.construct(str(match),
                               construct_with_topic_and_forum_views=True)
             self.sections.append(section)
Exemplo n.º 2
0
 def construct(self, html, construct_with_topic_and_forum_views=False):
     parser = requestor.BeautifulSoup(html, 'html.parser')
     title_element = parser.select_one(
         'div:is(.inner) ul:is(.topiclist) li:is(.header) dl:is(.row-item) dt div:is(.list-inner)'
     )
     if title_element == None:
         raise ConstructError('title_element == None')
     if not title_element.find('a') == None:
         title_element = title_element.a
     if title_element.has_attr('href'):
         self.link = title_element['href']
     self.title = title_element.text
     self.title = self.title.strip()
     if construct_with_topic_and_forum_views:
         for match in parser.select(ForumView().selector('section')):
             fv = ForumView()
             try:
                 fv.construct(str(match))
                 self.items.append(fv)
             except ConstructError as ce:
                 raise ConstructError('fv.construct threw ContructError: ' +
                                      ce.msg)
         for match in parser.select(TopicView().selector('section')):
             tv = TopicView()
             try:
                 tv.contruct(str(match))
                 self.items.append(tv)
             except ConstructError as ce:
                 raise ConstructError(
                     'tv.construct threw ConstructError: ' + ce.msg)
Exemplo n.º 3
0
 def construct(self, html):
     p1 = requestor.BeautifulSoup(html, 'html.parser')
     title_link = p1.select_one('a:is(.forumtitle)')
     if title_link == None:
         raise ConstructError('title_link == None')
     if title_link.has_attr('href'):
         self.url = title_link['href']
     self.title = title_link.text
     self.title = self.title.strip()
Exemplo n.º 4
0
 def contruct(self, html):
     if html == None:
         raise ConstructError('html == None')
     parser = requestor.BeautifulSoup(html, 'html.parser')
     topictitle = parser.select_one('a:is(.topictitle)')
     if topictitle == None:
         raise ConstructError('topictitle == None')
     if not topictitle.has_attr('href'):
         raise ConstructError('not topictitle.has_attr(\'href\')')
     self.url = topictitle['href']
     i = topictitle.find('i')
     if i != None:
         i.decompose()
     self.title = topictitle.text
     self.title = self.title.strip()