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


Python scrapy.http方法代碼示例

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


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

示例1: parse

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def parse(self, response: Response) -> Iterator[Request]:
        self.log(response)

        if getattr(self, 'validate_html', False):
            yield Request(
                'http://127.0.0.1:9988/?out=json',
                method='POST',
                headers={'Content-Type': response.headers['Content-Type']},
                body=response.body,
                callback=self._vnu_callback(response.url),
                errback=self.error_callback,
            )

        for link in LxmlLinkExtractor(deny_domains=self.deny_domains, deny_extensions=['doc'],
                                      tags=self.tags, attrs=self.attrs, deny=self.deny,
                                      canonicalize=False).extract_links(response):
            yield from self._make_requests(link.url) 
開發者ID:zulip,項目名稱:zulip,代碼行數:19,代碼來源:spiders.py

示例2: parse

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def parse(self, response):
        content_list = json.loads(response.body)
        jianshu_user_article_item = JianShuUserArticleItem()
        for i in range(len(content_list)):
            url = content_list[i]['object']['data']['slug']
            url = 'http://www.jianshu.com/p/{}'.format(url)
            title = content_list[i]['object']['data']['title']
            picture_url = content_list[i]['object']['data']['list_image_url']
            day = content_list[i]['object']['data']['first_shared_at']
            day = day.replace('T',' ')[:19]
            info_time = parser.parse(day)

            jianshu_user_article_item['pictureUrls'] = picture_url
            jianshu_user_article_item['title'] = title
            jianshu_user_article_item['url'] = url
            jianshu_user_article_item['publishTime'] = info_time
            yield jianshu_user_article_item 
開發者ID:huangtao1208,項目名稱:scrapy_spider,代碼行數:19,代碼來源:jianshu_user_article_spider.py

示例3: __proxy

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def __proxy(self, line):
        # print line
        if '//' in line:
            p = "%s" % line
            htt = line.split(':')[0]
        else:
            p = "http://%s" % line
            htt = "http"
        h = urllib2.ProxyHandler({htt: p})
        o = urllib2.build_opener(h, urllib2.HTTPHandler)
        try:
            r = o.open("http://www.baidu.com/", timeout=3)
            if len(r.read()) > 10:
                return p
            else:
                print "[!] {%s} NONO !" % p
        except:
            print "[!] {%s} NONO !" % p 
開發者ID:openslack,項目名稱:openslack-crawler,代碼行數:20,代碼來源:pipelines.py

示例4: parse

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def parse(self, response):

        if 'kuaidaili.com' in response.url:
            for d in range(1, 11):
                new_url = "http://www.kuaidaili.com/proxylist/%d/" % d
                yield Request(url=new_url, callback=self.fllow_parse)

        if 'cn-proxy.com' in response.url:
            yield Request(url='http://www.cn-proxy.com/', callback=self.fllow_parse)

        if 'proxy-list.org' in response.url:
            for i in range(1, 11):
                pa_url = "http://proxy-list.org/english/index.php?p=%d" % i
                yield Request(url=pa_url, callback=self.fllow_parse)

        if "vipiu.net" in response.url:
            for n in range(2, 5):
                if n == 1:
                    url_v = "http://vipiu.net/free/mianfeidaili/2014/04/27/42417.html"
                else:
                    url_v = "http://vipiu.net/free/mianfeidaili/2014/04/27/42417_%d.html" % n
                yield Request(url=url_v, callback=self.fllow_parse) 
開發者ID:openslack,項目名稱:openslack-crawler,代碼行數:24,代碼來源:proxy.py

示例5: __init__

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def __init__(self, url=None, *args, **kwargs):
		super(RedSpider, self).__init__(*args, **kwargs)
		# self.allowed_domains = [url]
		# self.start_urls = ["http://" + url]
		input = kwargs.get('urls', '').split(',') or []
		self.allowed_domains = input
		self.start_urls = ["http://" + input[0]] 
開發者ID:mertsarica,項目名稱:hack4career,代碼行數:9,代碼來源:RedScanner.py

示例6: parse_start_url

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def parse_start_url(self, response):
        js = response.xpath('//script[@type="commment"]').extract()[0]
        data = re.search('\{[\s\S]*\}', js).group(0)
        data = json.loads(data)
        region_list = data['BizAreaList']
        category_list = data['CateList'][0]['subCategories']

        for category in category_list:
            if category['name'] == u'全部':
                continue
            for region in region_list:
                if region['name'] == u'全城':
                    continue
                for area in region['subareas']:
                    if area['name'] == u'全部':
                        continue
                    item = MeituanItem()
                    item['province'], item['city'] = [s.split('=')[1] for s in response.xpath('//meta[@name="location"]/@content').extract()[0].split(';')]
                    item['region'] = region['name'].strip()
                    item['area'] = area['name'].strip()
                    item['category'] = category['name'].strip()
                    url = 'http://i.meituan.com/%s?cid=%d&bid=%d&cateType=poi&stid=_b1'%(pinyin.get(item['city']), category['id'], area['id'])

                    yield Request(url,
                            method='GET',
                            meta={'item': item, 'url': url},
                            headers=headers,
                            cookies=None,
                            body=None,
                            priority=0,
                            errback=None,
                            encoding=response.encoding,
                            callback=self.parse_category_area) 
開發者ID:piaotiejun,項目名稱:restaurant,代碼行數:35,代碼來源:meituan.py

示例7: _is_external_url

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def _is_external_url(self, url: str) -> bool:
        return url.startswith('http') or self._has_extension(url) 
開發者ID:zulip,項目名稱:zulip,代碼行數:4,代碼來源:spiders.py

示例8: __init__

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def __init__(self, response: scrapy.http.Response):
        self.response = response 
開發者ID:scrapinghub,項目名稱:scrapy-poet,代碼行數:4,代碼來源:test_middleware.py

示例9: __call__

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def __call__(self):
        data = {
            'product': {
                'url': 'http://example.com/sample',
                'name': 'Sample',
            },
        }
        return DummyProductResponse(data=data) 
開發者ID:scrapinghub,項目名稱:scrapy-poet,代碼行數:10,代碼來源:test_utils.py

示例10: test_get_callback

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def test_get_callback():
    spider = MySpider()

    req = scrapy.Request("http://example.com")
    assert get_callback(req, spider) == spider.parse

    req = scrapy.Request("http://example.com", spider.parse2)
    assert get_callback(req, spider) == spider.parse2

    def cb(response):
        pass

    req = scrapy.Request("http://example.com", cb)
    assert get_callback(req, spider) == cb 
開發者ID:scrapinghub,項目名稱:scrapy-poet,代碼行數:16,代碼來源:test_utils.py

示例11: test_is_response_going_to_be_used

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def test_is_response_going_to_be_used():
    spider = MySpider()

    request = scrapy.Request("http://example.com")
    assert is_response_going_to_be_used(request, spider) is True

    request = scrapy.Request("http://example.com", callback=spider.parse2)
    assert is_response_going_to_be_used(request, spider) is True

    request = scrapy.Request("http://example.com", callback=spider.parse3)
    assert is_response_going_to_be_used(request, spider) is False

    request = scrapy.Request("http://example.com", callback=spider.parse4)
    assert is_response_going_to_be_used(request, spider) is False

    request = scrapy.Request("http://example.com", callback=spider.parse5)
    assert is_response_going_to_be_used(request, spider) is True

    request = scrapy.Request("http://example.com", callback=spider.parse6)
    assert is_response_going_to_be_used(request, spider) is True

    request = scrapy.Request("http://example.com", callback=spider.parse7)
    assert is_response_going_to_be_used(request, spider) is True

    request = scrapy.Request("http://example.com", callback=spider.parse8)
    assert is_response_going_to_be_used(request, spider) is False

    request = scrapy.Request("http://example.com", callback=spider.parse9)
    assert is_response_going_to_be_used(request, spider) is True

    request = scrapy.Request("http://example.com", callback=spider.parse10)
    assert is_response_going_to_be_used(request, spider) is False

    request = scrapy.Request("http://example.com", callback=spider.parse11)
    assert is_response_going_to_be_used(request, spider) is True

    request = scrapy.Request("http://example.com", callback=spider.parse12)
    assert is_response_going_to_be_used(request, spider) is True 
開發者ID:scrapinghub,項目名稱:scrapy-poet,代碼行數:40,代碼來源:test_utils.py

示例12: start_requests

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def start_requests(self):

        for i in range(1, 11):
            url = self.base_url + str(i) + '_1' + self.end_Url
            yield Request(url, self.parse)  # 各類小說的連接

        yield Request('http://www.23us.com/quanben/1', self.parse)  # 全本小說的連接 
開發者ID:yyyy777,項目名稱:crawler,代碼行數:9,代碼來源:spider_dingdian.py

示例13: parse

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def parse(self, response):

        max_num = BeautifulSoup(response.text, 'lxml').find(
            'div', class_='pagelink').find_all('a')[-1].get_text()
        baseurl = str(response.url)[:27]
        for num in range(1, int(max_num) + 1):
            if baseurl == 'http://www.23us.com/quanben':
                url = baseurl + '/' + str(num)
            else:
                url = baseurl + '_' + str(num) + self.end_Url
            yield Request(url, callback=self.get_name) 
開發者ID:yyyy777,項目名稱:crawler,代碼行數:13,代碼來源:spider_dingdian.py

示例14: parse_js_links

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def parse_js_links(self, response):
		requests = []
		base_url = AbsUrl(response.url)

		jscall_regex = re.compile("\S+\((.*?)\)", re.M | re.S)
		for a in response.xpath('//a'):
			href = a.xpath('@href').extract()
			if href is not None and len(href) > 0:
				href = href[0]
			else:
				continue
			if href.find('javascript') != -1:
				onclick = a.xpath('@onclick').extract()
				if onclick is not  None and len(onclick) > 0:
					onclick = onclick[0]
				else:
					continue
				matches = jscall_regex.findall(onclick)
				if matches:
					jscall = matches[0]
					jscall_args = jscall.split(',')
					url = jscall_args[0].strip('\'').strip('\"')

					if url == '':
						continue						
					if not url.startswith('http'):
						url = base_url.extend(url)
					requests.append(Request(url, meta={'js_link': True}, headers={'Referer': response.url}))
					log.debug('adding js url: %s'%url)

		return requests 
開發者ID:amol9,項目名稱:imagebot,代碼行數:33,代碼來源:bot.py

示例15: __init__

# 需要導入模塊: import scrapy [as 別名]
# 或者: from scrapy import http [as 別名]
def __init__(self, book_url=None, **kw):
        super(FollowAllSpider, self).__init__(**kw)

        url = book_url
        if not url.startswith('http://') and not url.startswith('https://'):
            url = 'http://%s/' % url
        self.url = url
        self.allowed_domains = [re.sub(r'^www\.', '', urlparse(url).hostname)]
        self.link_extractor = LinkExtractor()
        self.cookies_seen = set()
        self.previtem = 0
        self.items = 0
        self.timesec = datetime.datetime.utcnow() 
開發者ID:scrapy,項目名稱:scrapy-bench,代碼行數:15,代碼來源:followall.py


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