0

0

不会写代码 用DeepSeek实现爬虫

星夢妙者

星夢妙者

发布时间:2025-11-03 09:35:01

|

704人浏览过

|

来源于php中文网

原创

我们以抓取博客内容为例,为大家展示如何操作。

#抓取标题与链接#

使用Python获取我的博客中所有文章的标题及其对应链接。(需翻页处理,各页面URL规律如下:第二页为https://www.php.cn/link/2c2c5fd01b61e3e0e687573af8f7e1fa/page/2/,第三页为 https://www.php.cn/link/649f7e2bf4d7efb62d56f6090cf943eb https://www.php.cn/link/9191b0a3b4c41e6732dbb644bd52d6fc 将最终结果导出为csv文件。文章标题的HTML结构示例如下:

    <h2 class="m-t-xs text-ellipsis index-post-title text-title"><a href="https://www.php.cn/link/2c2c5fd01b61e3e0e687573af8f7e1fa/4234.html">Homeassistant界面美化</a></h2>

HAPPY TEACHER'S DAY

Tago AI
Tago AI

AI生成带货视频,专为电商卖货而生

下载

不会写代码 用DeepSeek实现爬虫可以看到,讲解非常详细。

运行生成的代码,效果如下:

不会写代码 用DeepSeek实现爬虫接下来,我们尝试更复杂一点的任务:提取每篇文章的阅读次数、评论数量以及发布时间。

不会写代码 用DeepSeek实现爬虫新建对话内容如下:

#抓取文章阅读量、评论数、发布日期#

很好,之前的代码已经成功获取了博客的所有标题和链接。现在我需要你进入每一篇文章的具体页面,提取其阅读量、评论数和发布时间。相关HTML代码结构如下:

HAPPY TEACHER'S DAY

不会写代码 用DeepSeek实现爬虫不会写代码 用DeepSeek实现爬虫实际运行效果

不会写代码 用DeepSeek实现爬虫完整代码如下

import requests
from bs4 import BeautifulSoup
import csv
import re
import time
<p>def get_post_details(url, headers):
try:
response = requests.get(url, headers=headers)
response.raise_for_status()
except Exception as e:
print(f"获取文章详情失败:{url},错误:{str(e)}")
return None, None, None</p><p>soup = BeautifulSoup(response.text, 'html.parser')</p><h1>提取发布时间</h1><p>date<em>li = soup.find('li', class</em>='meta-date')
post_date = date_li.find('time').text.strip() if date_li else ''</p><h1>提取阅读量</h1><p>views<em>li = soup.find('li', class</em>='meta-views')
views = 0
if views_li:
views_text = views<em>li.find('span', class</em>='meta-value').text
match = re.search(r'(\d+)', views_text.replace(' ', ' '))
views = match.group(1) if match else 0</p><h1>提取评论数</h1><p>comments<em>li = soup.find('li', class</em>='meta-comments')
comments = 0
if comments_li:
comments_tag = comments<em>li.find('a', class</em>='meta-value') or comments<em>li.find('span', class</em>='meta-value')
if comments_tag:
match = re.search(r'(\d+)', comments_tag.text)
comments = match.group(1) if match else 0</p><p>return post_date, views, comments</p><p>def get_all_posts():
base_url = "<a href="https://www.php.cn/link/2c2c5fd01b61e3e0e687573af8f7e1fa">https://www.php.cn/link/2c2c5fd01b61e3e0e687573af8f7e1fa</a>"
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3'
}</p><p>all_data = []
page_num = 1</p><p>while True:</p><h1>构造分页链接</h1><pre class="brush:php;toolbar:false;">   url = f"{base_url}/page/{page_num}/" if page_num > 1 else base_url

   try:
       response = requests.get(url, headers=headers)
       response.raise_for_status()
   except Exception as e:
       print(f"停止在第 {page_num} 页,错误:{str(e)}")
       break

   soup = BeautifulSoup(response.text, 'html.parser')
   posts = soup.find_all('div', class_='post_title_wrapper')

   if not posts:
       break

   for post in posts:
       h2_tag = post.find('h2', class_='index-post-title')
       if not h2_tag:
           continue

       a_tag = h2_tag.find('a')
       if a_tag and a_tag.has_attr('href'):
           title = a_tag.text.strip()
           link = a_tag['href']

           # 获取文章详细信息
           post_date, views, comments = get_post_details(link, headers)

           # 汇总数据
           all_data.append([
               title,
               link,
               post_date,
               views,
               comments
           ])

           # 添加请求间隔,避免对服务器造成压力
           time.sleep(0.5)

   print(f"已处理第 {page_num} 页,累计文章数:{len(all_data)}")
   page_num += 1

写入CSV文件

with open('blog_posts_full.csv', 'w', newline='', encoding='utf-8-sig') as f: writer = csv.writer(f) writer.writerow(['标题', '链接', '发布日期', '阅读量', '评论数']) writer.writerows(all_data)

return len(all_data)

if name == "main": count = get_all_posts() print(f"完整数据已保存到 blog_posts_full.csv,总计 {count} 篇文章")

示例输出

""" 已处理第 1 页,累计文章数:10 已处理第 2 页,累计文章数:20 ... 完整数据已保存到 blog_posts_full.csv,总计 56 篇文章 """

总结:

借助DeepSeek,我们可以轻松生成所需的爬虫代码。当然,前提是我们必须清晰准确地描述需求!

相关文章

AI工具
AI工具

AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型,支持联网搜索。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

192

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

19

2026.02.03

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2910

2024.08.16

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

38

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

83

2026.03.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号