xpath-csv_doban_slider

项目要求:

使用xpath批量化获取豆瓣单页数据,并使用csv保存数据

思路:

1.安装xpath所需工具包

2.引用所用到的方法

3.爬取对应网页的数据

4.使用csv保存

注意点:

1.xpath是xlml库中extree的方法

2.xpath适用于HTML格式字符串,需要将获取的数据通过.HTML()方法返回一个Python对象再使用

3.enumerate()函数返回(下标,元素)或是(下标,键名)元组,可以使用拆包

4.使用xpath爬取单页数据多个目标数据,关键点在于xpath路径的修改

5.csv格式可用表格打开,所设置第一个列表为表头

python 复制代码
import csv
import requests
from lxml import etree

url = "https://movie.douban.com/top250"
headers = {"user-agent":
"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/137.0.0.0 Safari/537.36 Edg/137.0.0.0"}
response = requests.get(url,headers=headers)
data = response.text
data_x = etree.HTML(data)
res1 = data_x.xpath('//*[@id="content"]/div/div[1]/ol/li/div/div[2]/div[1]/a/span[1]/text()')
res2= data_x.xpath('//*[@id="content"]/div/div[1]/ol/li/div/div[2]/div[2]/p[1]/text()[1]')

text = [
    ['排名', '电影名称', '导演主演']
]
for i,j in enumerate(res1):
    text_=text.append([i+1,j,res2[i]])
with open('电影单页_xpath.csv', 'w', encoding='utf-8-sig', newline='') as file:
    writer = csv.writer(file)
    writer.writerows(text)
相关推荐
用户8358086187911 小时前
基于 Self-RAG 与列表级重排序的进阶 RAG 系统设计与实现
python
Warson_L18 小时前
Python `Annotated` 与 LangGraph Reducer 学习笔记
python
韩师傅18 小时前
海天线算法的前世今生
python·计算机视觉
韩师傅18 小时前
当你的甲方设备过烂,要如何快速出效果?
python·计算机视觉
Warson_L18 小时前
LangGraph的MessageState and HumanMessage
python
韩师傅18 小时前
当你的甲方吐槽天空不够蓝,你应该如何应对
python·计算机视觉
Warson_L19 小时前
python的类&继承
python
Warson_L19 小时前
类型标注/type annotation
python
ThreeS21 小时前
手搓MiniVLA全实战教程-一步一步用pytorch解释原理与思路
人工智能·python
金銀銅鐵1 天前
[Python] 模 n 乘法的逆元计算器
python·数学·游戏