【发布时间】:2017-01-08 12:17:25
【问题描述】:
这是我的第一篇文章,所以你好世界!
我正在使用“requests”和“lxml”在 Python3 中编写一个小型网络爬虫。我已经做了一个,这是针对不同网站的第二个项目。
我遇到了奇怪的结果 - xpath 方法返回所有标签,而不是选定的 DIV。更糟糕的是,输出乘以“offer-detail”DIV 的出现次数。
Xpath 计数返回正确的 DIV 数量,我还做了一个 page.content 转储到文件并手动检查,一切都是正确的。我已经使用 Chrome 的“Xpath helper”插件在网站上检查了 xpath - screenshot
Scraper 输出 - http://pastebin.com/1bEdzXdJ(又长又乱)
但在我的第一个项目中,没有发生这样的事情,它仍然返回正确的输出。
抓取网址:http://www.ibood.com/pl/pl/all-deals/
我非常感谢移动高级用户的任何帮助:)
代码:
import requests
from fake_useragent import UserAgent
from lxml import html
ua = UserAgent()
header_data = {'User-Agent': ua.chrome}
website = 'http://www.ibood.com/pl/pl/all-deals/'
page = requests.get(website, headers=header_data)
document = html.fromstring(page.content)
# //div[@class="all-offers"]/div/div[@class="offer-wrap"]
# # /div[@class="offer-detail"]
deals = document.xpath('//div[@class="offer-detail"]')
count = document.xpath('count(//div[@class="offer-detail"])')
print('count: ' + str(count))
for deal in deals:
print(deal.xpath('//text()'))
【问题讨论】:
标签: python python-3.x xpath web-scraping lxml