豆瓣数据采集案例

一般方法(基础的写法):

1.url:

2.解析获取数据

3.翻页

4.下一页继续采集【下一页数据与上一页是否完全相同】

具体代码如下:

复制代码
import time
import subprocess
from playwright.sync_api import sync_playwright
'''

先采集一页
翻页
'''
# 启动浏览器
path = r"C:\Users\six\AppData\Local\ms-playwright\chromium-1187\chrome-win\chrome.exe"
params = "--remote-debugging-port=7899"
cmd = f'"{path}" {params}'
subprocess.Popen(cmd)

# 等待浏览器启动完毕
time.sleep(2)

# 连接浏览器
with sync_playwright() as pw:
    browser = pw.chromium.connect_over_cdp("http://127.0.0.1:7899")
    context = browser.contexts[0]
    page = context.pages[0]

    # 访问目标网站
    page.goto('https://movie.douban.com/top250?start=200&filter=')

    for page_no in range(15):
        page.wait_for_timeout(1000)
        # 定位所有电影信息
        li_list = page.locator('//*[@id="content"]/div/div[1]/ol/li').all()
        # print(li_list)
        for li in li_list:
            num = li.locator('xpath=./div/div[1]/em').inner_text()
            title = li.locator('xpath=./div/div[2]/div[1]/a/span[1]').inner_text()
            score = li.locator('xpath=./div/div[2]/div[2]/div/span[2]').inner_text()
            img_url = li.locator('xpath=./div/div[1]/a/img').get_attribute("src")
            print(num, title, score, img_url)

        page.wait_for_timeout(1000)

        # 定位 后页 按钮
        next_ele = page.locator('//*[@id="content"]/div/div[1]/div[2]/span[3]/a')
        if next_ele.count() != 0:(即存在的情况下)
            # 滚动到下一页按钮所在位置
            next_ele.scroll_into_view_if_needed()
            #滚动到当前页面可见
            page.wait_for_timeout(1000)
            #停顿一下
            # 存在下一页
            print("存在下一页")
            next_ele.click()
        else:
            print("不存在下一页了!!")
            break

    input("...")

如何判断是否采集完毕

通过这个按钮是否存在来判断的,但如果是其他网站呢,因为这个案例可以做,其他不一定

像这样...的情况用这种方法可能会出错

接下来进行网易云的数据提取分析,要保证登陆状态,用本地启动的方式

具体的代码(完整代码)

复制代码
import time
import subprocess
from playwright.sync_api import sync_playwright
'''
注意事项:
1. 评论数据存在于 iframe 中,需要先切换到 iframe
2. 页面中的 id 值有产生变化,定位的时候需要找固定的值定位
'''
# 启动浏览器
path = r"C:\Users\six\AppData\Local\ms-playwright\chromium-1187\chrome-win\chrome.exe"
params = "--remote-debugging-port=7899"
cmd = f'"{path}" {params}'
subprocess.Popen(cmd)

# 等待浏览器启动完毕
time.sleep(2)

# 连接浏览器
with sync_playwright() as pw:
    browser = pw.chromium.connect_over_cdp("http://127.0.0.1:7899")
    context = browser.contexts[0]
    page = context.pages[0]

    # 访问目标网站
    page.goto('https://music.163.com/#/song?id=204072')

    # # 测试,查看页面数据
    # with open("wyy.html", "w", encoding="utf-8") as f:
    #     f.write(page.content())

    # 切换 iframe
    frame = page.frame("contentFrame")

    # # 测试,查看页面数据
    # with open("wyy.html", "w", encoding="utf-8") as f:
    #     f.write(frame.content())

    # 定位评论数据
    div_list = frame.locator('//div[@class="cmmts j-flag"]/div').all()

    for div in div_list:
        content = div.locator('xpath=.//div[@class="cnt f-brk"]').all_inner_texts()
        print(content)

    # if div.count() != 0:
    #     print("存在div")
    # else:
    #     print("不存在div!!")

    # # 定位 下一页 按钮
    # # next_ele = frame.locator('//*[@id="auto-id-oWpR0XOSkKJpJFBE"]')
    # next_ele = frame.locator('//a[text()="下一页"]')
    #
    # if next_ele.count() != 0:
    #     # 滚动到下一页按钮所在位置
    #     next_ele.scroll_into_view_if_needed()
    #     page.wait_for_timeout(1000)
    #     # 存在下一页
    #     print("存在下一页")
    #     # next_ele.click()
    # else:
    #     print("不存在下一页了!!")

    input("...")

采集到的数据中进行搜索,却发现找不到内容,可能是iframe,因为这也可能导致找不到这个元素,在网页中进行搜索iframe,发现找到了好几个iframe,说明其存在于iframe,z在iframe中进行搜索

切换到iframe但是还没有,可能是定位的问题,看看是否变成iframe中的数据

涉及页面数据的变化

那怎么办?通过ID之外进行定位

在这里发现class的znxt没有发生变化(定位不到一定要看相应的文本)

在复制中完整的xpath如果发生变化,就不能再用

最后得到,这里其实是同级关系

相关推荐
树欲静·而风不止8 分钟前
拿 DeepSeek 的免费对话搓了个 Everything 的静态 WebUI
ai·js
MATLAB代码顾问25 分钟前
Python实现蜂群算法优化TSP问题
开发语言·python·算法
之歆26 分钟前
DAY08_CSS浮动与行内块布局实战指南(下)
前端·css
yaodong51837 分钟前
不会Python也能数据分析:Gemini 3.1 Pro解决办公问题的SQL自动生成
python·sql·数据分析
yqcoder44 分钟前
CSS Position 全解析:5 种定位模式详解
前端·css
BU摆烂会噶1 小时前
【LangGraph】持久化实现的三大能力——时间旅行
数据库·人工智能·python·postgresql·langchain
Rhi6371 小时前
从零搭建项目:React 19 + Vite 8 + Tailwind CSS v4 实战配置
前端
竹林8181 小时前
用Viem替代ethers.js:从一次签名失败到完整迁移的实战记录
前端·javascript
之歆1 小时前
DAY08_CSS浮动与行内块布局实战指南(上)
前端·css
消失的旧时光-19432 小时前
统一并发模型:线程、Reactor、协程本质是一件事(从线程到协程 · 第6篇·终章)
java·python·算法