Comments (6)
能描述清楚一点么?
from ruia.
我在一个页面在抓取到urllist,在这个页面上可以看到该url的简介,然后我再请求这个url的详情,想把简介和详情信息组合起来,我现在是利用response.metadata传过去了,不知道这样合不合理
from ruia import *
from ruia_ua import middleware
import aiofiles
class CatalogueItem(Item):
target_item = TextField(css_select="div.info")
title = TextField(css_select="div.title",default="")
link = AttrField(css_select="a", attr="href")
class PageItem(Item):
target_item = TextField(css_select='div.msg')
info = TextField(css_select='span>label',many=True,default="")
class LianjiaSpider(Spider):
start_urls = ["https://bj.lianjia.com/chengjiao/pg"+str(i)+"/" for i in range(1,2)]
request_config = {"RETRIES": 3, "DELAY":1, "TIMEOUT": 20}
concurrency = 20
async def parse(self, response: Response):
catalogue = []
async for cat in CatalogueItem.get_items(html=response.html):
catalogue.append(cat)
urls = [page.link for page in catalogue]
async for response in self.multiple_request(urls, is_gather=True):
title = catalogue[response.index].title
link = catalogue[response.index].link
response.metadata.update({"title":title,"link":link})
yield self.parse_page(response)
async def parse_page(self, response):
async for item in PageItem.get_items(html=response.html):
self.metadata.update(response.metadata)
yield item
async def process_item(self, item):
print (self.metadata)
print (item.info)
if name == "main":
LianjiaSpider.start(middleware=middleware)
from ruia.
self.metadata是什么东西。
async def parse(self, response: Response):
catalogue = []
async for cat in CatalogueItem.get_items(html=response.html):
catalogue.append(cat)
urls = [page.link for page in catalogue]
async for response in self.multiple_request(urls, is_gather=True):
title = catalogue[response.index].title
link = catalogue[response.index].link
response.metadata.update({"title":title,"link":link})
yield self.parse_page(response)
async def parse_page(self, response):
async for item in PageItem.get_items(html=response.html):
first_info = response.metadata
second_info = item.info
这样就行了
from ruia.
因为想在process_item里面一起处理 后面入库
from ruia.
因为想在process_item里面一起处理 后面入库
按照让上面说的那样也可以实现,如果非要到process_item,可以将response.dat赋值给item的属性
from ruia.
嗯好的 学习了
from ruia.
Related Issues (20)
- Would be nice to be able to pass in "start_urls" HOT 7
- Trouble scraping deck.tk/deckstats.net HOT 7
- python3.9 remove asyncio.Task.all_tasks() HOT 3
- 【suggestion】重试逻辑可以添加或更换代理ip HOT 8
- 运行示例代码报错 HOT 10
- 代理使用问题 HOT 1
- 是否可以用模式匹配工具-pampy来实现对json解析的支持 HOT 1
- 并发5,循环爬取1000个网页,CPU耗尽为0,但是内存没有耗完,大佬帮看看代码有什么问题 HOT 3
- POST发送请求,收不到请求中的body HOT 2
- httpx替换aiohttp支持http2 HOT 1
- 我应当如何向 Spider 传递 start_urls? HOT 1
- 示例代码运行报错 HOT 3
- worker_numbers 数值多少合适 HOT 1
- ruia 使用lxml编码xml文档时报错 HOT 1
- 希望添加更多功能,更多示例,更多文档,希望长期维护~
- 通过中间件添加 socks5 代理后如何关闭 session?
- docs.python-ruia.org is not available HOT 4
- 如果能支持分布式就好了
- Logs HOT 1
- 请问如何判断发生了跳转呢? HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from ruia.