为了账号安全,请及时绑定邮箱和手机立即绑定

爬虫为啥只爬了2行?奇怪,附上源码

爬虫为啥只爬了2行?奇怪,附上源码

abc的大哥 2018-05-04 22:22:45
spider_main:import html_downloader import url_manager import html_parser import html_outputer import traceback class SpiderMain(object):     def __init__(self):         self.urls = url_manager.UrlManager()         self.downloader = html_downloader.HtmlDownloader()         self.parser = html_parser.HtmlParser()         self.outputer = html_outputer.HtmlOutputer()          def craw(self,root_url):         count = 1          self.urls.add_new_url(root_url)         while self.urls.has_new_url():             try:                 new_url = self.urls.get_new_url()                 print 'craw %d : %s' %(count,new_url)                 html_cont = self.downloader.download(new_url)                 new_urls,new_data = self.parser.parse(new_url,html_cont)                 self.urls.add_new_urls(new_urls)                 self.outputer.collect_data(new_data)                 if count == 1000:                     break                 count = count + 1             except:                traceback.print_exc()                print ('craw failed')         self.outputer.output_html()      if __name__=='__main__':     root_url = "http://baike.baidu.com/view/21087.htm"     obj_spider = SpiderMain()     obj_spider.craw(root_url)html_downloader:import urllib2 class HtmlDownloader(object):          def download(self,url):         if url is None:             return None                  response = urllib2.urlopen(url)                  if response.getcode() != 200:             return None                  return response.read()html_outputer:class HtmlOutputer(object):     def __init__(self):         self.datas = []               def collect_data(self,data):         if data is None:             return         self.datas.append(data)          def output_html(self):         fout = open('output.html','w')         fout.write('<html>')         fout.write("<head><meta charset=\"utf-8\"></head>")         fout.write('<body>')         fout.write('<table>')         for data in self.datas:             fout.write('<tr>')             fout.write('<td>%s</td>'%data['url'])             fout.write('<td>%s</td>'%data['title'].decode('utf-8').encode('utf-8'))             fout.write('<td>%s</td>'%data['summary'].decode('utf-8').encode('utf-8'))             fout.write('</tr>')         fout.write('</table>')         fout.write('</body>')         fout.write('</html>')         fout.close()url_manager:class UrlManager(object):     def __init__(self):         self.new_urls = set()         self.old_urls = set()               def add_new_url(self,url):         if url is None:             return         if url not in self.new_urls and url not in self.old_urls:             self.new_urls.add(url)          def add_new_urls(self,urls):         if urls is None or len(urls) == 0:             return         for url in urls:             self.add_new_url(url)          def has_new_url(self):         return len(self.new_urls) != 0          def get_new_url(self):         new_url = self.new_urls.pop()         self.old_urls.add(new_url)         return new_urlhtml_parser:from bs4 import BeautifulSoup import re import urlparse class HtmlParser(object):          def _get_new_urls(self,page_url,soup):         new_urls = set()         #/view/123/htm         links = soup.find_all('a',href=re.compile(r"/view/\d+\.htm"))         for link in links:             new_url = link['href']             new_full_url = urlparse.urljoin(page_url,new_url)             new_urls.add(new_full_url)         return new_urls                      def _get_new_data(self,page_url,soup):         res_data = {}         #res_data['url'] = page_url         #<dd class="lemmaWgt-lemmaTitle-title"> <h1>Python</h1>         title_node = soup.find('dd',class_="lemmaWgt-lemmaTitle-title").find("h1")         res_data['title'] = title_node.get_text()                  #<div class="lemma-summary">         summary_node = soup.find('div',class_="lemma-summary")         res_data['summary'] = summary_node.get_text()                  return res_data          def parse(self,page_url,html_cont):         if page_url is None or html_cont is None:             return                  soup = BeautifulSoup(html_cont,'html.parser',from_encoding='utf-8')         new_urls = self._get_new_urls(page_url,soup)         new_data = self._get_new_data(page_url,soup)                  return new_urls,new_data最后我用的python版本是2.7版本的
查看完整描述

目前暂无任何回答

  • 0 回答
  • 0 关注
  • 923 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信