当前位置: 首页 > news >正文

Python爬虫所需的技术及其原理(简单易懂)

导言

随着互联网的发展,大量的数据被存储在网络上,而我们需要从中获取有用的信息。Python作为一种功能强大且易于学习的编程语言,被广泛用于网络爬虫的开发。本文将详细介绍Python爬虫所需的技术及其原理,并提供相关的代码案例。

1. HTTP请求与响应

当然,我可以用Python的requests库来演示HTTP请求与响应的详细过程。requests库是Python中用于发送HTTP请求的第三方库,它简化了HTTP请求的发送和响应的接收过程。

首先,确保你已经安装了requests库。如果还没有安装,可以通过pip安装:

pip install requests

接下来,我将演示如何使用requests库发送一个GET请求到某个网站(例如https://httpbin.org/,这是一个用于HTTP请求的测试和模拟的网站),并接收并打印出响应的状态码、响应头和响应体。

Python代码示例

import requests# 目标URL
url = 'https://httpbin.org/get'# 发送GET请求
response = requests.get(url)# 打印响应的状态码
print(f'Status Code: {response.status_code}')# 打印响应头
print('Response Headers:')
for header, value in response.headers.items():print(f'{header}: {value}')# 打印响应体(以文本形式)
print('\nResponse Body:')
print(response.text)# 如果你知道响应是JSON格式的,也可以直接使用.json()方法将其解析为Python字典
# 注意:这里httpbin.org/get返回的是一个简单的HTML页面,所以这里只是演示
# 正常情况下,如果URL是返回JSON的(如httpbin.org/ip),你可以这样做:
# data = response.json()
# print(data)

代码解析

  1. 导入requests库:首先,你需要导入requests库,以便使用它提供的函数来发送HTTP请求。

  2. 定义URL:然后,你需要定义你想要发送请求的URL。在这个例子中,我们使用https://httpbin.org/get,这是一个会返回你发送给它的GET请求信息的网站。

  3. 发送GET请求:使用requests.get(url)发送GET请求到指定的URL,并将返回的响应对象存储在response变量中。

  4. 打印响应的状态码:通过response.status_code获取响应的状态码,并打印出来。状态码是一个整数,用于表示请求的结果,如200表示成功,404表示未找到资源等。

  5. 打印响应头:通过遍历response.headers.items()来打印响应头。响应头是一个包含多个键值对的字典,每个键值对代表了一个响应头字段和它的值。

  6. 打印响应体:通过response.text获取响应体的文本内容,并打印出来。如果响应体是JSON格式的,你可以使用response.json()方法将其解析为Python字典。但是,请注意,在这个例子中,https://httpbin.org/get返回的实际上是一个HTML页面,所以我们只是简单地打印了文本内容。

2. 网页解析技术

爬虫的网页解析技术主要涉及到从HTTP响应中提取并解析出所需数据的过程。这些技术通常依赖于一些库或框架来简化HTML、XML或JSON等格式的解析工作。在Python中,常用的网页解析库有BeautifulSouplxmlre(正则表达式)以及pandas(对于表格数据)等。下面,我将以BeautifulSoup为例,结合代码来详细讲解网页解析技术。

1. 安装BeautifulSoup和lxml

首先,你需要安装beautifulsoup4lxml(作为解析器)库。你可以通过pip来安装它们:

pip install beautifulsoup4 lxml

2. 使用BeautifulSoup解析网页

假设我们有一个HTML字符串或者已经从网页中获取了HTML内容,我们将使用BeautifulSoup来解析它并提取数据。

示例HTML内容
<html>
<head><title>示例页面</title>
</head>
<body><h1>欢迎来到我的网站</h1><p class="content">这是网页的主要内容部分。</p><ul id="links"><li><a href="http://example.com/link1">链接1</a></li><li><a href="http://example.com/link2">链接2</a></li></ul>
</body>
</html>
Python代码示例
from bs4 import BeautifulSoup# 假设html_content是从网页获取的HTML内容,这里我们直接用一个字符串代替
html_content = """
<html>
<head><title>示例页面</title>
</head>
<body><h1>欢迎来到我的网站</h1><p class="content">这是网页的主要内容部分。</p><ul id="links"><li><a href="http://example.com/link1">链接1</a></li><li><a href="http://example.com/link2">链接2</a></li></ul>
</body>
</html>
"""# 使用BeautifulSoup解析HTML内容
soup = BeautifulSoup(html_content, 'lxml')  # 使用lxml作为解析器# 提取标题
title = soup.title.text
print(f"标题: {title}")# 提取特定类名的段落内容
paragraph = soup.find('p', class_='content').text
print(f"内容: {paragraph}")# 提取所有链接的href属性
links = [a['href'] for a in soup.find_all('a', href=True)]
print(f"链接: {links}")# 提取具有特定ID的<ul>标签中的所有<li>标签的文本
list_items = [li.text for li in soup.find('ul', id='links').find_all('li')]
print(f"列表项: {list_items}")

代码讲解

  • 创建BeautifulSoup对象:首先,我们使用BeautifulSoup类创建一个对象,将HTML内容作为第一个参数传入,并指定解析器(这里使用的是lxml)。
  • 提取标题:通过.title.text可以直接获取<title>标签内的文本。
  • 提取特定类名的段落内容:使用.find()方法,并指定标签名和类名(class_作为参数名,因为class是Python的保留字),然后获取.text属性。
  • 提取链接:使用.find_all()方法查找所有<a>标签,并通过列表推导式获取每个<a>标签的href属性。
  • 提取具有特定ID的列表项:首先使用.find()方法找到具有特定ID的<ul>标签,然后在其内部使用.find_all()方法查找所有<li>标签,并获取它们的文本内容。

以上就是通过BeautifulSoup进行网页解析的一个基本示例和代码讲解。你可以根据实际需要调整HTML内容和解析逻辑。

3. 爬虫框架

在实际的爬虫开发中,我们通常会使用一些爬虫框架,它们提供了更高级别的抽象和更方便的功能。以下是一些常用的Python爬虫框架。

3.1 Scrapy

Scrapy是一个快速、可扩展且高级别的Web爬取框架。它提供了强大的抓取功能和数据处理能力,使爬虫开发更加高效。下面是一个使用Scrapy爬取网页的示例代码:

import scrapy  class MySpider(scrapy.Spider):  name = 'example.com'  start\_urls = \['http://www.example.com'\]  def parse(self, response):  \# 处理响应  \# 提取数据  \# 发送更多请求  pass
3.2 BeautifulSoup + requests

BeautifulSoup和requests的组合是另一种常用的爬虫开发方式。使用BeautifulSoup解析网页,使用requests发送HTTP请求。

下面是一个使用BeautifulSoup和requests爬取网页的示例代码:

import requests  
from bs4 import BeautifulSoup  url = 'http://www.example.com'  
response = requests.get(url)  
soup = BeautifulSoup(response.text, 'html.parser')  
\# 处理页面,提取数据
3.3 Selenium

Selenium是一种自动化浏览器工具,可以模拟浏览器行为。它通常与浏览器驱动一起使用,如ChromeDriver。使用Selenium可以解决一些JavaScript渲染的网页爬取问题。

下面是一个使用Selenium模拟浏览器爬取网页的示例代码(需要使用selenium库):

from selenium import webdriver  driver = webdriver.Chrome('path/to/chromedriver')  
driver.get('http://www.example.com')  
\# 处理页面,提取数据  
driver.quit()
4. 其他

除了了解基本的爬虫工作原理,还需要掌握一些相关的技术,以便更好地应对各种复杂情况。下面是几个常用的技术要点:

4.1 User-Agent伪装

为了防止网站屏蔽爬虫,我们可以在发送HTTP请求时设置User-Agent头部,将其伪装成浏览器的请求。这样可以减少被服务器识别为爬虫的概率。

Python requests库可以通过设置headers参数来添加自定义的HTTP头部。

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'  
}  
response = requests.get(url, headers\=headers)
4.2 反爬虫策略与解决方法

为了防止被爬虫抓取数据,网站可能会采取一些反爬虫策略,如限制请求频率、设置验证码、使用动态加载等。对于这些情况,我们可以采取以下解决方法:

  • 限制请求频率:可以通过设置合适的时间间隔来控制请求的频率,避免过快访问网站。

  • 验证码识别:可以使用第三方的验证码识别库(如Tesseract-OCR)来自动识别并输入验证码。

  • 动态加载页面:对于使用JavaScript动态加载的页面,可以使用Selenium库模拟浏览器行为进行处理。

4.3 网页登录与Session管理

有些网站需要登录后才能获取到所需的数据。在这种情况下,我们可以通过模拟登录行为,发送POST请求并记录登录后的Session信息,以便后续的数据访问。

下面是一个使用requests库模拟登录的示例代码:

import requests  login\_url = 'https://example.com/login'  
data = {  'username': 'your\_username',  'password': 'your\_password'  
}  
response = requests.post(login\_url, data\=data)  
session = response.cookies  data\_url = 'https://example.com/data'  
response = requests.get(data\_url, cookies\=session)  
data = response.text

在这个示例中,我们首先发送POST请求模拟登录,将用户名和密码作为表单数据data发送给登录页面login_url,并保存返回的Session信息。

然后我们可以使用requests.get()方法发送GET请求,同时将保存的Session信息作为cookies参数传入,以便获取登录后的数据。

5. 实例:爬取简书网站文章信息

为了更好地演示Python爬虫的技术和原理,我们选取了简书网站作为示例。我们将爬取简书网站中的热门文章列表,提取出每篇文章的标题、作者和链接。

以下是完整的实现代码:

import requests  
from bs4 import BeautifulSoup  \# 发送HTTP请求  
url = 'https://www.jianshu.com'  
response = requests.get(url)  
html = response.text  \# 解析HTML内容  
soup = BeautifulSoup(html, 'html.parser')  \# 提取数据  
articles = soup.select('.note-list li')  data = \[\]  
for article in articles:  title = article.select('a.title')\[0\].string.strip()  author = article.select('.name')\[0\].string.strip()  href = 'https://www.jianshu.com' + article.select('a.title')\[0\]\['href'\]  data.append(\[title, author, href\])  \# 数据存储  
import csv  
with open('jianshu\_articles.csv', 'w', newline\='', encoding\="utf-8") as file:  writer = csv.writer(file)  writer.writerows(data)

在这个示例中,我们首先发送GET请求获取简书网站的HTML内容,然后使用BeautifulSoup库进行解析。

接着,我们使用CSS选择器字符串.note-list li选取所有文章的外层容器,并使用CSS选择器和字典键值对的方式提取文章的标题、作者和链接。

最后,我们采用CSV格式将提取的数据保存到了名为jianshu_articles.csv的文件中。

结语

本文详细介绍了Python爬虫所需的技术及其原理,包括HTTP请求与响应、网页解析技术和爬虫框架。通过掌握这些技术,我们可以有效地开发出强大且高效的Python爬虫。希望本文能对你理解和掌握Python爬虫有所帮助。

请注意,在进行网络爬虫时,需要遵守网站的使用条款,并遵守相关法律法规。同时,合理使用爬虫技术,不对网络资源进行滥用和破坏。

相关文章:

Python爬虫所需的技术及其原理(简单易懂)

导言 随着互联网的发展&#xff0c;大量的数据被存储在网络上&#xff0c;而我们需要从中获取有用的信息。Python作为一种功能强大且易于学习的编程语言&#xff0c;被广泛用于网络爬虫的开发。本文将详细介绍Python爬虫所需的技术及其原理&#xff0c;并提供相关的代码案例。…...

FxFactory 8 for Mac 视觉特效插件包安装

Mac分享吧 文章目录 介绍页面效果一、下载软件二、开始安装1、Install安装2、显示软件页面&#xff0c;表示安装成功3、补丁安装 三、注意事项1、若已安装过其他版本&#xff0c;需要使用软件自带的卸载功能进行软件卸载&#xff0c;再安装此版本 安装完成&#xff01;&#x…...

将语义分割的标签转换为实例分割(yolo)的标签

语义分割的标签&#xff08;目标处为255&#xff0c;其余处为0&#xff09; 实例分割的标签&#xff08;yolo.txt&#xff09;,描述边界的多边形顶点的归一化位置 绘制在原图类似蓝色的边框所示。 废话不多说&#xff0c;直接贴代码&#xff1b; import os import cv2 imp…...

QT 遍历ini配置文件

在 Qt 中&#xff0c;处理 INI 配置文件是一项常见任务&#xff0c;通常使用 QSettings 类来读取和写入这些文件。QSettings 提供了一种方便的方式来操作 INI 文件中的配置数据。下面是如何使用 QSettings 遍历和处理 INI 配置文件的示例。 示例代码 假设有一个名为 config.i…...

ecmascript和javascript的区别详细讲解

​ 大家好&#xff0c;我是程序员小羊&#xff01; 前言&#xff1a; ECMAScript 和 JavaScript是紧密相关的术语&#xff0c;但它们有着各自明确的定义和用途。要理解它们的区别&#xff0c;首先需要从它们的起源、发展历史、技术架构以及具体应用领域来分析。以下是对它们的详…...

【Python报错已解决】“ModuleNotFoundError: No module named ‘timm‘”

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 文章目录 引言&#xff1a;一、问题描述1.1 报错示例&#xff1a;当我们尝试导入timm库时&#xff0c;可能会看到以下错误信息。…...

「图::存储」链式邻接表|链式前向星(C++)

前置知识 上一节我们介绍了三种基本的存图结构&#xff1a; 「图」邻接矩阵|边集数组|邻接表&#xff08;C&#xff09; 概述 他们各有优劣&#xff0c;为了综合他们的性能&#xff0c; 这一节我们来介绍两种以这三种结构为基础实现的高级存储结构&#xff1a;链式邻接表|…...

《Cloud Native Data Center Networking》(云原生数据中心网络设计)读书笔记 -- 10数据中心中的BGP

本章解答以下问题&#xff1a; ASN&#xff0c;团体&#xff08;community&#xff09;&#xff0c;属性&#xff08;attribute&#xff09;&#xff0c;最佳路径这些BGP术语是什么疑似&#xff1f;在数据中心中应该使用eBGP还是iBGP?在数据中心使用BGP时&#xff0c;应采用什…...

unity游戏开发——标记物体 一目了然

Unity游戏开发:标记物体,让开发变得一目了然 “好读书&#xff0c;不求甚解&#xff1b;每有会意&#xff0c;便欣然忘食。” 本文目录&#xff1a; Unity游戏开发 Unity游戏开发:标记物体,让开发变得一目了然前言1. 什么是Tag&#xff1f;2. Unity中如何添加和管理Tag步骤1&am…...

vue 项目打包图片没有打包进去问题解决

解决方法1.在导入图片的文件中通过 import 引入图片 这种方法只适合图片少的情况 <template> <img :srctestImg/> </template> <script> import testImg from /assets/img/testImg.png </script>2.封装公共方法,通过 new URL() 的方式…...

TCP的传输速度

如何确定TCP最大传输速度&#xff1f; TCP 的传输速度&#xff0c;受限于发送窗⼝&#xff0c;接收窗⼝以及⽹络设备传输能⼒。 其中&#xff0c;窗⼝⼤⼩由内核缓冲区⼤⼩决定。如果缓冲区与⽹络传输能⼒匹配&#xff0c;那么缓冲区的利⽤率就达到了最⼤化。 如何计算网络传…...

直播间的“骆驼”比沙漠还多?刀郎演唱会惊现“骆驼”

“送战友&#xff0c;踏征程&#xff0c;默默无语两行泪&#xff0c;耳边响起驼铃声……”8月30日&#xff0c;刀郎知交线上演唱会在微信视频号直播。一曲《驼铃》&#xff0c;勾起了无数人的回忆&#xff0c;离别的伤感、人性的关怀与温暖&#xff0c;通过悠然的旋律流入千万听…...

Android Studio gradle下载太慢了!怎么办?(已解决)

Android Studio&#xff01;你到底干了什么&#xff1f;&#xff01; 不能高速下载gradle&#xff0c;我等如何进行app编程&#xff1f;&#xff01; 很简单&#xff0c;我修改gradle地址不就是了。 找到gradle-wrapper.properties文件 修改其中distributionUrl的地址。 将 ht…...

安卓版Infuse来了 打造自己的影视墙

如何让安卓设备上的视频播放更高效&#xff1f;AfuseKt 或许能给出答案 AfuseKt 是一款功能强大的安卓网络视频播放器&#xff0c;专为满足用户对多样化媒体播放需求而设计。它不仅支持多种流行的在线存储和媒体管理平台&#xff0c;如阿里云盘、Alist、WebDAV 和 Emby 等&…...

【Python时序预测系列】高创新模型:基于xlstm模型实现单变量时间序列预测(案例+源码)

这是我的第351篇原创文章。 一、引言 LSTM在1990年代被提出&#xff0c;用以解决循环神经网络&#xff08;RNN&#xff09;的梯度消失问题。LSTM在多种领域取得了成功&#xff0c;但随着Transformer技术的出现&#xff0c;其地位受到了挑战。如果将LSTM扩展到数十亿参数&#…...

Ubuntu 22.04 系统中 ROS2安装

Ubuntu 22.04 系统中 ROS2安装 ROS2安装 # 多窗口终端工具 sudo apt update sudo apt install tilix打开软件&#xff0c;点击右上角图标进入设置 -> General -> size120, columns:48Command -> 勾选第一个 Run command as login shellColor -> Theme Color 选择…...

Vue内置指令v-once、v-memo和v-pre提升性能?

前言 Vue的内置指令估计大家都用过不少&#xff0c;例如v-for、v-if之类的就是最常用的内置指令&#xff0c;但今天给大家介绍几个平时用的比较少的内置指令。毕竟这几个Vue内置指令可用可不用&#xff0c;不用的时候系统正常跑&#xff0c;但在对的地方用了却能提升系统性能&…...

OpenHarmony轻松玩转GIF数据渲染

OpenAtom OpenHarmony&#xff08;以下简称“OpenHarmony”&#xff09;提供了Image组件支持GIF动图的播放&#xff0c;但是缺乏扩展能力&#xff0c;不支持播放控制等。今天介绍一款三方库——ohos-gif-drawable三方组件&#xff0c;带大家一起玩转GIF的数据渲染&#xff0c;搞…...

torch.clip函数介绍

PyTorch 中,torch.clip函数用于对张量中的元素进行裁剪,将其值限制在指定的范围内。 一、函数语法及参数解释 torch.clip(input, min=None, max=None, out=None) input:输入张量,即要进行裁剪的张量。min(可选):裁剪的下限。如果未指定,则不进行下限裁剪。max(可选)…...

西北工业大学oj题-兔子生崽

题目描述&#xff1a; 兔子生崽问题。假设一对小兔的成熟期是一个月&#xff0c;即一个月可长成成兔&#xff0c;每对成兔每个月可以生一对小兔&#xff0c;一对新生的小兔从第二个月起就开始生兔子&#xff0c;试问从一对兔子开始繁殖&#xff0c;一年以后可有多少对兔子&…...

[特殊字符] 智能合约中的数据是如何在区块链中保持一致的?

&#x1f9e0; 智能合约中的数据是如何在区块链中保持一致的&#xff1f; 为什么所有区块链节点都能得出相同结果&#xff1f;合约调用这么复杂&#xff0c;状态真能保持一致吗&#xff1f;本篇带你从底层视角理解“状态一致性”的真相。 一、智能合约的数据存储在哪里&#xf…...

DAY 47

三、通道注意力 3.1 通道注意力的定义 # 新增&#xff1a;通道注意力模块&#xff08;SE模块&#xff09; class ChannelAttention(nn.Module):"""通道注意力模块(Squeeze-and-Excitation)"""def __init__(self, in_channels, reduction_rat…...

嵌入式学习笔记DAY33(网络编程——TCP)

一、网络架构 C/S &#xff08;client/server 客户端/服务器&#xff09;&#xff1a;由客户端和服务器端两个部分组成。客户端通常是用户使用的应用程序&#xff0c;负责提供用户界面和交互逻辑 &#xff0c;接收用户输入&#xff0c;向服务器发送请求&#xff0c;并展示服务…...

基于Java+VUE+MariaDB实现(Web)仿小米商城

仿小米商城 环境安装 nodejs maven JDK11 运行 mvn clean install -DskipTestscd adminmvn spring-boot:runcd ../webmvn spring-boot:runcd ../xiaomi-store-admin-vuenpm installnpm run servecd ../xiaomi-store-vuenpm installnpm run serve 注意&#xff1a;运行前…...

Qemu arm操作系统开发环境

使用qemu虚拟arm硬件比较合适。 步骤如下&#xff1a; 安装qemu apt install qemu-system安装aarch64-none-elf-gcc 需要手动下载&#xff0c;下载地址&#xff1a;https://developer.arm.com/-/media/Files/downloads/gnu/13.2.rel1/binrel/arm-gnu-toolchain-13.2.rel1-x…...

通过 Ansible 在 Windows 2022 上安装 IIS Web 服务器

拓扑结构 这是一个用于通过 Ansible 部署 IIS Web 服务器的实验室拓扑。 前提条件&#xff1a; 在被管理的节点上安装WinRm 准备一张自签名的证书 开放防火墙入站tcp 5985 5986端口 准备自签名证书 PS C:\Users\azureuser> $cert New-SelfSignedCertificate -DnsName &…...

nnUNet V2修改网络——暴力替换网络为UNet++

更换前,要用nnUNet V2跑通所用数据集,证明nnUNet V2、数据集、运行环境等没有问题 阅读nnU-Net V2 的 U-Net结构,初步了解要修改的网络,知己知彼,修改起来才能游刃有余。 U-Net存在两个局限,一是网络的最佳深度因应用场景而异,这取决于任务的难度和可用于训练的标注数…...

全面解析数据库:从基础概念到前沿应用​

在数字化时代&#xff0c;数据已成为企业和社会发展的核心资产&#xff0c;而数据库作为存储、管理和处理数据的关键工具&#xff0c;在各个领域发挥着举足轻重的作用。从电商平台的商品信息管理&#xff0c;到社交网络的用户数据存储&#xff0c;再到金融行业的交易记录处理&a…...

node.js的初步学习

那什么是node.js呢&#xff1f; 和JavaScript又是什么关系呢&#xff1f; node.js 提供了 JavaScript的运行环境。当JavaScript作为后端开发语言来说&#xff0c; 需要在node.js的环境上进行当JavaScript作为前端开发语言来说&#xff0c;需要在浏览器的环境上进行 Node.js 可…...

比特币:固若金汤的数字堡垒与它的四道防线

第一道防线&#xff1a;机密信函——无法破解的哈希加密 将每一笔比特币交易比作一封在堡垒内部传递的机密信函。 解释“哈希”&#xff08;Hashing&#xff09;就是一种军事级的加密术&#xff08;SHA-256&#xff09;&#xff0c;能将信函内容&#xff08;交易细节&#xf…...