这里我们用xpath爬取猪八戒网的信息
https://chongqing.zbj.com/search/f/?kw=python
首先我们打开猪八戒网,随便搜索一个服务,得到下面界面 data:image/s3,"s3://crabby-images/4867b/4867b3628dc40ef3092d6cb43da99c968989e39d" alt="在这里插入图片描述" 然后我们对网页进行分析,我们先打开网页源代码,观察我们所要爬取的内容是否存在于网页源代码内 data:image/s3,"s3://crabby-images/927d2/927d24b2a0294334b91da73cb90300ea175118e2" alt="在这里插入图片描述" 可以看出我们需要的内容就存在于网页源代码内,这时候我们需要分析网页的层级结构。 这是我们需要提取内容的所有供应商: data:image/s3,"s3://crabby-images/72763/7276304ff2825adc9a5e4b73a6b0590ce98912db" alt="在这里插入图片描述" 通过以下方法就可以获得所有供应商的层级关系,后面获取具体内容的层级关系也是依次类推 data:image/s3,"s3://crabby-images/21580/215808e5bbfbaf125f07ccadc0b6cb4e2bd8e943" alt="在这里插入图片描述" 好了,我们上代码:
import csv
import requests
from lxml import etree
url="https://chongqing.zbj.com/search/f/?kw=python"
resp=requests.get(url)
html=resp.text
tree=etree.HTML(html)
divs=tree.xpath("/html/body/div[6]/div/div/div[2]/div[5]/div[1]/div")
with open("猪八戒网.csv",'w',encoding='utf-8',newline='') as f:
writer=csv.writer(f)
writer.writerow(["名称","价格","供应商","交易记录","地点"])
for div in divs:
price=div.xpath("./div/div/a[2]/div[2]/div[1]/span[1]/text()")[0].strip("¥")
transactionrecord=div.xpath("./div/div/a[2]/div[2]/div[1]/span[2]/text()")[0]
title="python".join(div.xpath("./div/div/a[2]/div[2]/div[2]/p/text()"))
contractor="".join(div.xpath("./div/div/a[1]/div[1]/p/text()")).strip("\n")
place=div.xpath("./div/div/a[1]/div[1]/div/span/text()")[0]
writer.writerow([title,price,contractor,transactionrecord,place])
print("over!")
运行结果: data:image/s3,"s3://crabby-images/69f71/69f71d8923e5c38197b39ed6fc42f5bcd1e2f67b" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/61676/61676cc62400e9a8082853d6722255f88d908e29" alt="在这里插入图片描述"
|