當前位置: 首頁>>代碼示例>>Python>>正文


Python exceptions.IgnoreRequest方法代碼示例

本文整理匯總了Python中scrapy.exceptions.IgnoreRequest方法的典型用法代碼示例。如果您正苦於以下問題:Python exceptions.IgnoreRequest方法的具體用法?Python exceptions.IgnoreRequest怎麽用?Python exceptions.IgnoreRequest使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在scrapy.exceptions的用法示例。


在下文中一共展示了exceptions.IgnoreRequest方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _redirect

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def _redirect(self, redirected, request, spider, reason):
        ttl = request.meta.setdefault('redirect_ttl', self.max_redirect_times)
        redirects = request.meta.get('redirect_times', 0) + 1

        if ttl and redirects <= self.max_redirect_times:
            redirected.meta['redirect_times'] = redirects
            redirected.meta['redirect_ttl'] = ttl - 1
            redirected.meta['redirect_urls'] = request.meta.get('redirect_urls', []) + \
                [request.url]
            redirected.meta['redirect_reasons'] = request.meta.get('redirect_reasons', []) + \
                [reason]
            redirected.dont_filter = request.dont_filter
            redirected.priority = request.priority + self.priority_adjust
            logger.debug("Redirecting (%(reason)s) to %(redirected)s from %(request)s",
                         {'reason': reason, 'redirected': redirected, 'request': request},
                         extra={'spider': spider})
            return redirected
        else:
            logger.debug("Discarding %(request)s: max redirections reached",
                         {'request': request}, extra={'spider': spider})
            raise IgnoreRequest("max redirections reached") 
開發者ID:wistbean,項目名稱:learn_python3_spider,代碼行數:23,代碼來源:redirect.py

示例2: fetch

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def fetch(self, request_or_url, spider=None, redirect=True, **kwargs):
        if isinstance(request_or_url, Request):
            request = request_or_url
        else:
            url = any_to_uri(request_or_url)
            request = Request(url, dont_filter=True, **kwargs)
            if redirect:
                request.meta['handle_httpstatus_list'] = SequenceExclude(range(300, 400))
            else:
                request.meta['handle_httpstatus_all'] = True
        response = None
        try:
            response, spider = threads.blockingCallFromThread(
                reactor, self._schedule, request, spider)
        except IgnoreRequest:
            pass
        self.populate_vars(response, request, spider) 
開發者ID:wistbean,項目名稱:learn_python3_spider,代碼行數:19,代碼來源:shell.py

示例3: _log_download_errors

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def _log_download_errors(self, spider_failure, download_failure, request, spider):
        """Log and silence errors that come from the engine (typically download
        errors that got propagated thru here)
        """
        if (isinstance(download_failure, Failure) and
                not download_failure.check(IgnoreRequest)):
            if download_failure.frames:
                logger.error('Error downloading %(request)s',
                             {'request': request},
                             exc_info=failure_to_exc_info(download_failure),
                             extra={'spider': spider})
            else:
                errmsg = download_failure.getErrorMessage()
                if errmsg:
                    logger.error('Error downloading %(request)s: %(errmsg)s',
                                 {'request': request, 'errmsg': errmsg},
                                 extra={'spider': spider})

        if spider_failure is not download_failure:
            return spider_failure 
開發者ID:wistbean,項目名稱:learn_python3_spider,代碼行數:22,代碼來源:scraper.py

示例4: process_exception

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def process_exception(self, request, exception, spider):
        if isinstance(exception, (IgnoreRequest, DropItem)):
            return
        if not self._is_enabled_for_request(request):
            return

        autoextract = request.meta.pop(AUTOEXTRACT_META_KEY)
        stop_time = time.time()
        latency = time.time() - autoextract['timing']['start_ts']
        autoextract['timing'].update({'end_ts': stop_time, 'latency': latency})

        # Make sure to log all unknown failures
        logger.warning('AutoExtract failure after %.3fs for %s: %s',
                       latency,
                       autoextract['original_url'],
                       repr(exception),
                       extra={'spider': spider})

        request.meta['autoextract'] = autoextract
        ex_class = global_object_name(exception.__class__)
        self.inc_metric('autoextract/errors/total_count', spider=spider)
        self.inc_metric('autoextract/errors/type_count/%s' % ex_class, spider=spider) 
開發者ID:scrapinghub,項目名稱:scrapy-autoextract,代碼行數:24,代碼來源:middlewares.py

示例5: process_request

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def process_request(self, request, spider):

          # don't use this middleware while testing is site is up
        if hasattr(spider, "test") and spider.test=="yes":
            #logger = logging.getLogger()
            #logger.info("Testing mode, dead domains disabled")
            return None

        if not Domain.is_onion_url(request.url):
            return None

        domain = Domain.find_by_url(request.url)
        if not domain or domain.is_up:
            return None

        raise IgnoreRequest('Domain %s is dead, skipping' % domain.host) 
開發者ID:dirtyfilthy,項目名稱:freshonions-torscraper,代碼行數:18,代碼來源:middlewares.py

示例6: process_request

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def process_request(self, request, spider):
        if 'x-ignore-request' in request.url:
            raise IgnoreRequest()
        elif 'x-error-request' in request.url:
            _ = 1 / 0 
開發者ID:eren,項目名稱:sozlukcrawler,代碼行數:7,代碼來源:middleware.py

示例7: process_response

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def process_response(self, request, response, spider):
        if 'x-ignore-response' in request.url:
            raise IgnoreRequest()
        elif 'x-error-response' in request.url:
            _ = 1 / 0
        else:
            return response 
開發者ID:eren,項目名稱:sozlukcrawler,代碼行數:9,代碼來源:middleware.py

示例8: process_request

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def process_request(self, request, spider):
        if not request.url:
            return None
        channel_id = request.meta.get('channel_id', 0)
        # 處理詳情頁麵(忽略列表頁麵)與pipeline配合
        if is_dup_detail(request.url, spider.name, channel_id):
            raise IgnoreRequest("Spider: %s, DeDuplicationRequest: %s" % (spider.name, request.url)) 
開發者ID:zhanghe06,項目名稱:news_spider,代碼行數:9,代碼來源:de_duplication_request.py

示例9: process_request

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def process_request(self, request, spider):
        # 處理微信反爬(反爬機製一, sogou)
        if spider.name in ['weixin'] and 'antispider' in request.url:
            # 獲取來源鏈接
            redirect_urls = request.meta['redirect_urls']

            # 清理失效 cookies
            cookies_id = request.meta['cookiejar']
            del_cookies(spider.name, cookies_id)

            # spider.log(message='AntiSpider cookies_id: %s; url: %s' % (cookies_id, redirect_urls[0]))
            raise IgnoreRequest(
                'Spider: %s, AntiSpider cookies_id: %s; url: %s' % (spider.name, cookies_id, redirect_urls[0])) 
開發者ID:zhanghe06,項目名稱:news_spider,代碼行數:15,代碼來源:anti_spider.py

示例10: mustbe_deferred

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def mustbe_deferred(f, *args, **kw):
    """Same as twisted.internet.defer.maybeDeferred, but delay calling
    callback/errback to next reactor loop
    """
    try:
        result = f(*args, **kw)
    # FIXME: Hack to avoid introspecting tracebacks. This to speed up
    # processing of IgnoreRequest errors which are, by far, the most common
    # exception in Scrapy - see #125
    except IgnoreRequest as e:
        return defer_fail(failure.Failure(e))
    except Exception:
        return defer_fail(failure.Failure())
    else:
        return defer_result(result) 
開發者ID:wistbean,項目名稱:learn_python3_spider,代碼行數:17,代碼來源:defer.py

示例11: process_request_2

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def process_request_2(self, rp, request, spider):
        if rp is None:
            return
        if not rp.can_fetch(to_native_str(self._useragent), request.url):
            logger.debug("Forbidden by robots.txt: %(request)s",
                         {'request': request}, extra={'spider': spider})
            self.crawler.stats.inc_value('robotstxt/forbidden')
            raise IgnoreRequest("Forbidden by robots.txt") 
開發者ID:wistbean,項目名稱:learn_python3_spider,代碼行數:10,代碼來源:robotstxt.py

示例12: _logerror

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def _logerror(self, failure, request, spider):
        if failure.type is not IgnoreRequest:
            logger.error("Error downloading %(request)s: %(f_exception)s",
                         {'request': request, 'f_exception': failure.value},
                         exc_info=failure_to_exc_info(failure),
                         extra={'spider': spider})
        return failure 
開發者ID:wistbean,項目名稱:learn_python3_spider,代碼行數:9,代碼來源:robotstxt.py

示例13: _robots_error

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def _robots_error(self, failure, netloc):
        if failure.type is not IgnoreRequest:
            key = 'robotstxt/exception_count/{}'.format(failure.type)
            self.crawler.stats.inc_value(key)
        rp_dfd = self._parsers[netloc]
        self._parsers[netloc] = None
        rp_dfd.callback(None) 
開發者ID:wistbean,項目名稱:learn_python3_spider,代碼行數:9,代碼來源:robotstxt.py

示例14: media_failed

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def media_failed(self, failure, request, info):
        if not isinstance(failure.value, IgnoreRequest):
            referer = referer_str(request)
            logger.warning(
                'File (unknown-error): Error downloading %(medianame)s from '
                '%(request)s referred in <%(referer)s>: %(exception)s',
                {'medianame': self.MEDIA_NAME, 'request': request,
                 'referer': referer, 'exception': failure.value},
                extra={'spider': info.spider}
            )

        raise FileException 
開發者ID:wistbean,項目名稱:learn_python3_spider,代碼行數:14,代碼來源:files.py

示例15: process_request

# 需要導入模塊: from scrapy import exceptions [as 別名]
# 或者: from scrapy.exceptions import IgnoreRequest [as 別名]
def process_request(self, request, spider):
        if request.meta.get('dont_cache', False):
            return

        # Skip uncacheable requests
        if not self.policy.should_cache_request(request):
            request.meta['_dont_cache'] = True  # flag as uncacheable
            return

        # Look for cached response and check if expired
        cachedresponse = self.storage.retrieve_response(spider, request)
        if cachedresponse is None:
            self.stats.inc_value('httpcache/miss', spider=spider)
            if self.ignore_missing:
                self.stats.inc_value('httpcache/ignore', spider=spider)
                raise IgnoreRequest("Ignored request not in cache: %s" % request)
            return  # first time request

        # Return cached response only if not expired
        cachedresponse.flags.append('cached')
        if self.policy.is_cached_response_fresh(cachedresponse, request):
            self.stats.inc_value('httpcache/hit', spider=spider)
            return cachedresponse

        # Keep a reference to cached response to avoid a second cache lookup on
        # process_response hook
        request.meta['cached_response'] = cachedresponse 
開發者ID:wistbean,項目名稱:learn_python3_spider,代碼行數:29,代碼來源:httpcache.py


注:本文中的scrapy.exceptions.IgnoreRequest方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。