不会写代码 用DeepSeek实现爬虫

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

#抓取标题与链接#

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

    

Homeassistant界面美化

HAPPY TEACHER’S DAY

代码小浣熊 代码小浣熊

代码小浣熊是基于商汤大语言模型的软件智能研发助手,覆盖软件需求分析、架构设计、代码编写、软件测试等环节

代码小浣熊 51 查看详情 代码小浣熊

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

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

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

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

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

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

HAPPY TEACHER’S DAY

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

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

import requestsfrom bs4 import BeautifulSoupimport csvimport reimport time

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

soup = BeautifulSoup(response.text, 'html.parser')

提取发布时间

dateli = soup.find('li', class='meta-date')post_date = date_li.find('time').text.strip() if date_li else ''

提取阅读量

viewsli = soup.find('li', class='meta-views')views = 0if views_li:views_text = viewsli.find('span', class='meta-value').textmatch = re.search(r'(d+)', views_text.replace(' ', ' '))views = match.group(1) if match else 0

提取评论数

commentsli = soup.find('li', class='meta-comments')comments = 0if comments_li:comments_tag = commentsli.find('a', class='meta-value') or commentsli.find('span', class='meta-value')if comments_tag:match = re.search(r'(d+)', comments_tag.text)comments = match.group(1) if match else 0

return post_date, views, comments

def get_all_posts():base_url = "https://www.php.cn/link/2c2c5fd01b61e3e0e687573af8f7e1fa"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'}

all_data = []page_num = 1

while True:

构造分页链接

   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,我们可以轻松生成所需的爬虫代码。当然,前提是我们必须清晰准确地描述需求!

以上就是不会写代码 用DeepSeek实现爬虫的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/326369.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月5日 12:12:40
下一篇 2025年11月5日 12:14:24

相关推荐

  • python中list2什么意思

    在 Python 中,list2 表示列表的第二个元素。list2 等效于 my_list[1],其中 my_list 是列表。使用 list2 可以访问列表中指定索引的元素。 Python 中的 list2 含义 回答:list2 在 Python 中表示一个列表的第二个元素。 详细解释: 在 P…

    2025年12月13日
    000
  • python中出现raise异常如何解决

    python 中 raise 异常的解决方法 Python 中的 raise 语句用于主动引发异常。当代码中出现问题时,可以主动引发异常以终止程序或告知用户错误。 解决方法: 要解决 raise 异常,必须执行以下步骤: 理解错误消息:了解 raise 异常引发的确切错误消息,以便查明根本原因。检查…

    好文分享 2025年12月13日
    000
  • pycharm怎么导入numpy模块

    导入 NumPy 模块的步骤:使用 import numpy as np 语句import:导入模块numpy:NumPy 模块名称as np:分配别名(可选) 如何导入 NumPy 模块 导入 NumPy 模块 导入 NumPy 模块的步骤非常简单,只需使用以下语句: import numpy a…

    2025年12月13日
    000
  • pycharm怎么配置解释器

    PyCharm解释器的配置过程如下:安装Python解释器,推荐使用Python 3.x版本。打开PyCharm并新建一个项目。设置项目解释器,选择已安装的Python解释器。将添加的解释器设为默认解释器。 PyCharm 配置解释器 配置 PyCharm 解释器对于 Python 开发至关重要。通…

    2025年12月13日
    000
  • python import os什么意思

    Python 中 import os 的含义:导入 os 模块,提供操作系统相关功能。将 os 模块加载到解释器中,创建模块对象并将其添加到作用域中。启用访问 os 模块中定义的功能和常量,例如创建文件、执行命令等。 Python 中 import os 的含义 在 Python 中,import …

    2025年12月13日
    000
  • python中递归是什么意思

    Python 中的递归是一种强大技术,允许函数调用自身,从而可以简化代码,适用于需要遍历数据结构的问题和求解数学问题。但是,递归可能导致堆栈溢出和调试困难。替代方案包括使用迭代。 Python 中的递归 递归是一种计算机科学技术,它允许函数调用自身。它在 Python 中是一种强大的工具,可以用来解…

    2025年12月13日
    000
  • python中出现红色错误怎么办

    python 中红色错误的解决指南 什么是红色错误? 红色错误是 Python 中最严重的错误类型,表示解释器检测到一个无法解析的代码问题。这些错误通常会出现一条开头为 “SyntaxError” 的错误消息。 如何解决红色错误? 解决红色错误的第一步是仔细检查错误消息。错误…

    好文分享 2025年12月13日
    000
  • python中怎么创建列表

    在 Python 中,创建列表可以使用方括号 [],方法包括:创建空列表:my_list = []使用元素创建列表:my_list = [1, 2, 3, 4, 5]创建嵌套列表:my_list = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]使用 range() 函数创建连续…

    2025年12月13日
    000
  • python里面up是什么意思

    Python 中的 up 函数用于更新对象属性,类似于赋值运算符,但允许在不直接修改对象的情况下更改属性值。它使用语法 obj.up(attr, value),其中 obj 是对象,attr 是属性名称,value 是新属性值。与 += 运算符相比,up 直接更新属性值,不返回任何值,只能用于对象。…

    2025年12月13日
    000
  • python中args是什么意思

    Python 中 args 是一个特殊变量,用以接收函数中剩余未指定参数。它是一个包含任意参数列表的元组,允许函数接受比定义时更多参数,增强函数灵活性,使用时在函数定义中将 *args 作为参数,传入函数的额外参数都将存储在 args 元组中。 Python 中 args 的含义 在 Python …

    2025年12月13日
    000
  • array在python中什么意思

    Python 中的数组是一种高效有序集合,用于存储同类型数据。其特性包括:类型化:所有元素必须具有相同类型。高效:元素紧密排列,提供快速内存访问。支持 NumPy:可无缝集成,支持高级数据处理。扩展性强:可通过方法转换数据类型。 Python 中的数组 在 Python 中,“array”是一种用于…

    2025年12月13日
    000
  • Python中出现EOF错误怎么办

    如何处理 Python 中的 EOF 错误?最佳做法包括:1. 使用 try-except 块捕获 EOF 错误;2. 检查文件大小判断是否达到结尾;3. 使用循环逐行读取,捕获 StopIteration 异常;4. 利用文件指示器 f.tell() 与文件大小比较。 Python 中的 EOF …

    2025年12月13日
    000
  • python写代码怎么切换下一行

    在 Python 中,可以通过使用以下方法在代码中换行:’n’ 字符多行字符串.splitlines() 方法嵌入式换行符print() 函数的 end 参数 如何使用 Python 切换到下一行 在 Python 中,可以通过多种方法在代码中换行。 1. ‘n&…

    2025年12月13日
    000
  • 学python能干啥

    Python 的职业应用包括:数据科学和机器学习Web 开发软件工程金融科技人工智能自动化教育游戏开发其他应用(网络安全、云计算、生物信息学等) Python 的职业应用 Python 是一种多功能编程语言,广泛应用于各个领域。凭借其易用性、强大的库和开源社区,它成为技术领域炙手可热的技能。以下列举…

    2025年12月13日
    000
  • python中write的用法

    write() 函数用于向文件写入内容,覆盖现有内容。用法:使用 open() 函数打开文件并设置写入模式。使用 write() 函数写入内容。使用 close() 函数关闭文件。 Python 中的 write() 函数 write() 函数的作用: write() 函数用于向文件输出指定内容。它…

    2025年12月13日
    000
  • python中fact是什么意思

    Python 中的 fact 是 math 模块中 factorial 函数的别名,返回指定正整数或浮点数的阶乘,阶乘为将该数与小于或等于该数的所有正整数相乘的结果。 Python 中的 fact 在 Python 中,fact 是来自 math 模块中的 factorial 函数的别名。它返回给定…

    2025年12月13日
    000
  • prime在python是什么意思

    Python 中的 prime 是一个内建函数,它检查一个数字是否为素数。使用时,导入 math 模块,然后调用 prime 函数,传入要检查的数字。函数返回 True 表示素数,False 表示非素数。 Python 中的 Prime Prime 在 Python 中是什么意思? 在 Python…

    2025年12月13日
    000
  • import os在python中的意思

    import os 语句在 Python 中用于导入 os 模块,该模块提供与底层操作系统交互的功能。功能包括:访问和操作文件系统对象控制进程和任务获取操作系统和硬件信息提供便携接口 import os 在 Python 中的含义 在 Python 中,import os 语句用于导入 os 模块,…

    2025年12月13日
    000
  • python中的df是什么意思

    Python 中的 df 表示 DataFrame,一种类似于 Excel 电子表格的二维表形数据结构,用于存储和处理表格数据。其特点包括:行和列、不同数据类型、索引、丰富的操作符和函数。DataFrame 在数据分析中广泛应用,包括导入数据、清理数据、分析数据、创建可视化和进行建模。数据可通过索引…

    2025年12月13日
    000
  • import在python是什么意思

    Python 中的 import 用于导入外部模块或库,允许程序员使用他人编写的代码。导入模块时,可以使用 import module_name 语法。要仅导入特定元素,可以使用 from module_name import element1, element2, … 语法。impor…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信