一篇最全Python 爬虫超详细讲解(零基础入门,适合小白)

一篇最全Python 爬虫超详细讲解(零基础入门,适合小白)

爬虫是指通过编程自动从网页上获取信息的技术.想象你平时打开网页,右键点击 “查看源代码”,那些你看到的HTML代码就是网页的结构,而爬虫就像一位帮你阅读这些网页内容的“机器人”.

本文将详细讲解如何从零开始编写一个Python爬虫,即使是完全没接触过编程的朋友也能理解.

这里插播一条粉丝福利,如果你正在学习Python或者有计划学习Python,想要突破自我,对未来十分迷茫的,可以点击这里获取最新的Python学习资料和学习路线规划(免费分享,记得关注)  

一、爬虫的基本流程

  1. 发送请求:爬虫向目标网页发送请求,获取网页内容.
  2. 解析网页:从返回的网页内容中提取你需要的信息.
  3. 保存数据:将提取到的信息保存到文件或数据库中,以便后续分析.

二、常用爬虫库

在Python中,有两个非常流行的库用于爬虫开发:

  • requests:用于发送网络请求,获取网页内容.
  • BeautifulSoup:用于解析网页内容,提取需要的数据.
1. 安装库

首先,你需要安装这两个库.在命令行中执行以下命令:

pip install requests beautifulsoup4 -i https://pypi.tuna.tsinghua.edu.cn/simple 

三、简单爬虫示例

接下来,我们会编写一个简单的爬虫,从一个网页上获取数据.

1. 获取网页内容

第一步是使用 requests 库来获取网页的内容.我们以获取百度首页为例.

import requests # 发送请求获取网页内容 url = 'https://www.baidu.com' response = requests.get(url) # 打印网页内容 print(response.text) 
解释:
  • requests.get(url) 用于向指定网址发送请求并获取网页内容.
  • response.text 返回网页的HTML代码.

运行后,你会看到大量的HTML代码,这就是百度首页的内容.

2. 解析网页内容

获取网页内容后,我们需要用 BeautifulSoup 库来解析HTML,提取我们需要的信息.接下来我们解析百度首页的标题.

from bs4 import BeautifulSoup # 解析网页内容 soup = BeautifulSoup(response.text, 'html.parser') # 获取标题 title = soup.title.text print('网页标题:', title) 
解释:
  • BeautifulSoup(response.text, 'html.parser') 用于解析HTML内容.
  • soup.title.text 返回网页的标题.

输出:

makefile 网页标题: 百度一下,你就知道 
3. 提取更多信息

让我们继续提取网页中的链接(<a>标签中的 href 属性).这非常有用,例如你想抓取某个网站上的所有文章链接.

# 获取所有的<a>标签 links = soup.find_all('a') # 打印所有链接 for link in links:     href = link.get('href')     print(href) 
解释:
  • soup.find_all('a') 用于获取网页中的所有链接.
  • link.get('href') 获取每个链接的 href 属性,也就是网址.

四、爬虫的分类

1. 简单爬虫(静态网页)

如果网页是静态的,所有的数据直接在HTML代码中呈现,这种网页最容易爬取.以上示例就是一个典型的静态网页爬虫.

2. 动态爬虫(处理JavaScript生成的内容)

有些网页的数据不是直接在HTML中,而是通过JavaScript动态生成的.这类网页需要更复杂的处理方式,通常我们会使用 Selenium 这样的库来模拟浏览器操作.

安装 Selenium:
pip install selenium -i https://pypi.tuna.tsinghua.edu.cn/simple 

Selenium 可以像真实的用户一样与网页交互,甚至可以点击按钮、滚动页面等.比如要爬取动态生成的数据,我们可以使用Selenium来加载网页.

示例:
from selenium import webdriver # 设置浏览器驱动路径 driver = webdriver.Chrome() # 打开网页 driver.get('https://www.example.com') # 获取网页标题 print(driver.title) # 关闭浏览器 driver.quit() 
3. 爬虫框架(Scrapy)

当你需要大规模爬取数据时,可以使用专门的爬虫框架——Scrapy.Scrapy 是一个强大的爬虫框架,具有异步、高效的特点,适合用于构建复杂的爬虫.

安装 Scrapy:
pip install scrapy -i https://pypi.tuna.tsinghua.edu.cn/simple 

五、爬虫常见问题及解决方案

1. 网页反爬机制

有些网站不允许爬虫访问,通常会通过检测请求头或IP地址来防止爬虫访问.为了绕过这种限制,我们可以伪装成正常用户.

解决方法:添加请求头
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.36' } response = requests.get(url, headers=headers) 
2. 延迟访问

频繁访问某个网站可能会触发反爬机制,我们可以通过设置延迟避免这种问题.

import time # 延迟2秒后发送下一个请求 time.sleep(2) 
3. 代理IP

如果网站通过检测IP地址限制访问,我们可以使用代理IP.

proxies = {     'http': 'http://10.10.1.10:3128',     'https': 'https://10.10.1.10:1080', } response = requests.get(url, proxies=proxies) 

六、保存数据

当我们提取到需要的信息后,通常需要将数据保存起来,常见的保存方式有保存到CSV文件数据库.

1. 保存到CSV文件
import csv # 保存数据到CSV文件 with open('data.csv', 'w', newline='', encoding='utf-8') as file:     writer = csv.writer(file)     writer.writerow(['标题', '链接'])  # 写入表头     for link in links:         writer.writerow([link.text, link.get('href')]) 
2. 保存到数据库

可以使用 SQLite 或其他数据库,将数据保存到数据库中.

import sqlite3 # 连接数据库(如果不存在会自动创建) conn = sqlite3.connect('data.db') cursor = conn.cursor() # 创建表 cursor.execute('CREATE TABLE IF NOT EXISTS links (title TEXT, href TEXT)') # 插入数据 for link in links:     cursor.execute('INSERT INTO links (title, href) VALUES (?, ?)', (link.text, link.get('href'))) # 提交事务并关闭连接 conn.commit() conn.close() 

七、总结

  1. 爬虫的基本流程:发送请求,解析网页,提取并保存数据.
  2. 常用库requests 用于发送请求,BeautifulSoup 用于解析HTML.
  3. 进阶技术:处理动态网页需要用到 Selenium,而大规模爬取可以使用 Scrapy 框架.
  4. 应对反爬:通过伪装请求头、设置延迟以及使用代理IP等方式绕过反爬机制.

最后,我精心筹备了一份全面的Python学习大礼包,完全免费分享给每一位渴望成长、希望突破自我现状却略感迷茫的朋友。无论您是编程新手还是希望深化技能的开发者,都欢迎加入我们的学习之旅,共同交流进步!

🌟 学习大礼包包含内容:

Python全领域学习路线图:一目了然,指引您从基础到进阶,再到专业领域的每一步学习路径,明确各方向的核心知识点。

超百节Python精品视频课程:涵盖Python编程的必备基础知识、高效爬虫技术、以及深入的数据分析技能,让您技能全面升级。

实战案例集锦:精选超过100个实战项目案例,从理论到实践,让您在解决实际问题的过程中,深化理解,提升编程能力。

华为独家Python漫画教程:创新学习方式,以轻松幽默的漫画形式,让您随时随地,利用碎片时间也能高效学习Python。

互联网企业Python面试真题集:精选历年知名互联网企业面试真题,助您提前备战,面试准备更充分,职场晋升更顺利。

👉 立即领取方式:只需【点击这里】,即刻解锁您的Python学习新篇章!让我们携手并进,在编程的海洋里探索无限可能

 

Read more

AI学习路径 python到openclaw

AI学习路径 python到openclaw

从本地模型部署到构建全能AI助理的完整学习路径。我帮你把它们串联起来,可以这样理解: * Python:你的得力工具。用它来写代码,像指挥家一样,调用和控制下面所有的“乐队成员”。 * Ollama:你的本地模型“仓库”。它让你能在自己的电脑上轻松运行各种大语言模型,这是实现数据隐私和零成本调用的基础 。 * Trae:你的智能编程“战场”。这是一个AI IDE,你可以把通过Python和Ollama搭建的能力,在这里更高效地开发成应用 。 * OpenClaw:你的终极“行动家”。它像一个智能体的“操作系统”,能把AI的思考转化为在电脑上的具体行动,比如发邮件、管理文件 。 下面是一份为你梳理的学习路径指南: 🧭 第一阶段:打好基础,从Python出发 这是所有AI开发的起点。你需要掌握如何用Python与模型交互,而Ollama正是你本地运行模型的绝佳搭档。 * 核心技能:学会在Python环境中安装Ollama依赖库 ollama-python 或使用兼容OpenAI格式的 openai 库,通过简单的代码调用本地模型 。 * 实践要点: * 环境搭

By Ne0inhk
Python(30)基于itertools生成器的量子计算模拟技术深度解析

Python(30)基于itertools生成器的量子计算模拟技术深度解析

目录 * 引言:生成器与量子计算的完美邂逅 * 一、itertools生成器核心机制解析 * 1.1 无限序列生成器三剑客 * 1.2 组合生成器深度应用 * 二、量子计算模拟中的生成器革命 * 2.1 量子门序列动态生成 * 2.2 量子蒙特卡洛模拟优化 * 2.3 变分量子算法参数优化 * 三、生成器在量子计算中的创新应用 * 3.1 量子电路版本控制 * 3.2 量子数据流处理 * 四、生成器与量子计算的深度融合 * 4.1 量子退火算法优化 * 4.2 量子机器学习数据增强 * 五、生成器在量子计算中的性能优化 * 5.1 核心作用 * 5.2 优化方向 * 5.3 内存效率对比 * 5.

By Ne0inhk

物理模拟频繁失稳?,掌握这4种C++稳定性控制模式立刻见效

第一章:物理模拟稳定性问题的根源剖析 在开发游戏引擎、仿真系统或计算机动画时,物理模拟的稳定性是决定用户体验与计算可靠性的核心因素。不稳定的模拟可能导致物体穿模、异常抖动甚至程序崩溃。其根本原因通常可归结为数值积分误差、碰撞响应不合理以及刚体动力学参数设置不当。 数值积分方法的选择影响显著 物理引擎普遍采用数值积分方法更新物体状态,如位置和速度。其中欧拉法因实现简单被广泛使用,但其精度低、易发散。 // 简单欧拉法示例:易导致能量累积,引发不稳定 func eulerStep(pos, vel float64, dt, acc float64) (float64, float64) { vel += acc * dt // 速度更新 pos += vel * dt // 位置更新 return pos, vel } 相比之下,中点法或Verlet积分能提供更高稳定性,尤其在大时间步长下表现更优。 碰撞检测与响应中的隐患 当两个物体穿透后未能正确分离,连续帧中反复触发碰撞,将导致“振荡效应”。常见缓解策略包括: * 引入穿透补偿偏移(position

By Ne0inhk
【C++】类的默认成员函数下(内含日期类的实现)

【C++】类的默认成员函数下(内含日期类的实现)

文章目录 * 4.拷贝构造函数 * 5.赋值运算符重载 * 5.1 运算符重载 * 5.2 赋值运算符重载 * 6.取地址运算符重载 * 6.1 const成员函数 * 6.2 取地址运算符重载 * 7. 日期类实现 4.拷贝构造函数 如果一个构造函数的第一个参数是自身类类型的引用,且任何额外的参数都有默认值,则此构造函数也叫做拷贝构造函数,也就是说拷贝构造是一个特殊的构造函数。 拷贝构造的特点: 1.拷贝构造函数是构造函数的一个重载(无返回值)。 2.拷贝构造函数的第一个参数必须是当前类类型对象的引用(最好加上const,防止权限放大的问题),使用传值方式编译器直接报错,因为语法逻辑上会引发无穷递归调用。 拷贝构造函数也可以多个参数,但是第一个参数必须是类类型对象的引用,后面的参数必须有缺省值。 3.C++规定自定义类型对象进行拷贝行为必须调用拷贝构造,所以这里自定义类型传值传参和传值返回都会调用拷贝构造函数。 4.若未显式定义拷贝构造,编译器会自动生成拷贝构造函数。自动生成的拷贝构造对内置类型成员变量会完成值拷贝/浅拷贝

By Ne0inhk