【Python网络爬虫笔记】14-使用代理绕过访问限制

news2025/2/27 19:29:49

【Python网络爬虫笔记】14-网络代理

    • 目录
    • 什么是代理?
    • 为什么需要使用代理?
    • 代理的类型
    • 如何在Python中使用代理?
      • 使用`requests`库设置代理
      • 使用`urllib`库设置代理
      • 使用`scrapy`框架设置代理
    • 典型案例:使用代理爬取豆瓣电影Top250
      • 步骤1:安装依赖库
      • 步骤2:编写爬虫代码
      • 步骤3:运行代码
    • 总结

在网络爬虫开发中,代理(Proxy)是一个非常重要的工具。它可以帮助我们隐藏真实IP地址、绕过访问限制、提高爬取效率等。本文将详细介绍如何在Python网络爬虫中使用代理,并提供一个典型案例来帮助大家更好地理解代理的应用。

目录

  1. 什么是代理?
  2. 为什么需要使用代理?
  3. 代理的类型
  4. 如何在Python中使用代理?
  5. 典型案例:使用代理爬取豆瓣电影Top250
  6. 总结

什么是代理?

代理服务器(Proxy Server)是位于客户端和目标服务器之间的中间服务器。当我们通过代理服务器发送请求时,目标服务器看到的是代理服务器的IP地址,而不是我们的真实IP地址。这样,代理服务器可以起到隐藏真实IP、缓存数据、过滤内容等作用。
免费代理网站:
在这里插入图片描述

为什么需要使用代理?

在网络爬虫中,使用代理有以下几个主要原因:

  1. 隐藏真实IP:防止目标网站封禁我们的IP地址。
  2. 绕过访问限制:有些网站会根据IP地址限制访问频率或地区,使用代理可以绕过这些限制。
  3. 提高爬取效率:通过多个代理IP轮换请求,可以避免因频繁请求而被封禁。
  4. 数据采集:有些网站会根据用户的地理位置显示不同的内容,使用代理可以获取不同地区的数据。

代理的类型

代理服务器可以根据不同的标准进行分类,常见的分类方式有:

  1. 匿名性

    • 透明代理:目标服务器可以识别出我们使用了代理,并且知道我们的真实IP。
    • 匿名代理:目标服务器知道我们使用了代理,但不知道我们的真实IP。
    • 高匿代理:目标服务器无法识别出我们使用了代理,也无法获取我们的真实IP。
  2. 协议

    • HTTP代理:主要用于HTTP请求。
    • HTTPS代理:主要用于HTTPS请求。
    • SOCKS代理:支持多种协议,包括HTTP、HTTPS、FTP等。
  3. 来源

    • 免费代理:免费提供的代理IP,通常不稳定且速度较慢。
    • 付费代理:付费使用的代理IP,通常更稳定、速度更快。

如何在Python中使用代理?

在Python中,使用代理非常简单。我们可以通过requests库或urllib库来设置代理。下面是一些常见的用法示例。

使用requests库设置代理

requests库是Python中最常用的HTTP库之一,它提供了非常简单的接口来设置代理。

import requests

# 设置代理
proxies = {
    'http': 'http://10.10.1.10:3128',
    'https': 'http://10.10.1.10:1080',
}

# 发送请求
response = requests.get('http://example.com', proxies=proxies)

# 输出响应内容
print(response.text)

在这里插入图片描述

使用urllib库设置代理

urllib是Python标准库中的一个模块,也可以用来设置代理。

import urllib.request

# 设置代理
proxy_handler = urllib.request.ProxyHandler({
    'http': 'http://10.10.1.10:3128',
    'https': 'http://10.10.1.10:1080',
})

# 创建opener
opener = urllib.request.build_opener(proxy_handler)

# 发送请求
response = opener.open('http://example.com')

# 输出响应内容
print(response.read().decode('utf-8'))

使用scrapy框架设置代理

如果我们使用的是scrapy框架,可以通过在settings.py中设置代理。

# settings.py
PROXY = 'http://10.10.1.10:3128'

# 在middleware中使用代理
class ProxyMiddleware(object):
    def process_request(self, request, spider):
        request.meta['proxy'] = PROXY

# 启用middleware
DOWNLOADER_MIDDLEWARES = {
    'myproject.middlewares.ProxyMiddleware': 350,
}

典型案例:使用代理爬取豆瓣电影Top250

下面我们通过一个典型案例来演示如何在Python网络爬虫中使用代理。我们将使用requests库和代理来爬取豆瓣电影Top250的数据。

步骤1:安装依赖库

首先,我们需要安装requests库和BeautifulSoup库。

pip install requests beautifulsoup4

步骤2:编写爬虫代码

import requests
from bs4 import BeautifulSoup

# 设置代理
proxies = {
    'http': 'http://your-proxy-ip:port',
    'https': 'http://your-proxy-ip:port',
}

# 豆瓣电影Top250的URL
url = 'https://movie.douban.com/top250'

# 发送请求
try:
    response = requests.get(url, proxies=proxies, 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.raise_for_status()
except requests.exceptions.RequestException as e:
    print("请求失败:", e)
    exit()

# 解析HTML内容
soup = BeautifulSoup(response.text, 'html.parser')

# 提取电影信息
movies = soup.find_all('div', class_='hd')
for movie in movies:
    title = movie.a.span.text
    print("电影标题:", title)

步骤3:运行代码

运行上述代码后,我们将看到豆瓣电影Top250的电影标题被成功爬取并打印出来。通过使用代理,我们可以有效地隐藏真实IP地址,避免被目标网站封禁。

总结

在Python网络爬虫中使用代理是一个非常实用的技巧,可以帮助我们隐藏真实IP、绕过访问限制、提高爬取效率等。本文介绍了代理的基本概念、类型以及在Python中使用代理的方法,并通过一个典型案例演示了如何在实际项目中应用代理。

希望这些内容对大家有所帮助!如果大家有任何问题或建议,欢迎在评论区留言讨论。


参考资料

  • Requests库官方文档
  • urllib官方文档
  • Scrapy官方文档

标签:Python, 网络爬虫, 代理, requests, BeautifulSoup, 豆瓣电影

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2307020.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux中Shell运行原理和权限(下)(4)

文章目录 前言一、Shell的运行原理二、Linux当中的权限问题Linux权限的概念如何将普通用户添加到信任列表 三、Linux权限管理文件访问者的分类(人)文件类型和访问权限(事物属性)文件权限值的表示方法文件访问权限的相关设置方法如…

OceanBase数据库实战:Windows Docker部署与DBeaver无缝对接

一、前言 OceanBase 是一款高性能、高可扩展的分布式数据库,适用于大规模数据处理和企业级应用。 随着大数据和云计算的普及,OceanBase 在企业数字化转型中扮演着重要角色。学习 OceanBase 可以帮助开发者掌握先进的分布式数据库技术,提升数…

技术速递|.NET 9 网络优化

作者:Mňa,Natalia,Anton 排版:Alan Wang 秉承我们的传统,我们很高兴与您分享这篇博客文章,以介绍新的 .NET 版本中网络领域相关的最新动态和最有趣的变化。今年,我们带来了 HTTP 领域的改变、新…

Tag标签的使用

一个非常适合运用在vue项目中的组件:Tag标签。 目录 一、准备工作 1、安装element-plus库 2、配置element-plus库 二、Tag标签入门 1、打开element官网,搜索tag标签 2、体验Tag标签的基础用法 三、Tag标签进阶训练1 1、定义一个数组,…

Linux:(3)

一:Linux和Linux互传(压缩包) scp:Linux scp 命令用于 Linux 之间复制文件和目录。 scp 是 secure copy 的缩写, scp 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令。 scp 是加密的,rcp 是不加密的,scp 是…

HarmonyOS 5.0应用开发——鸿蒙接入高德地图实现POI搜索

【高心星出品】 文章目录 鸿蒙接入高德地图实现POI搜索运行结果:准备地图编写ArkUI布局来加载HTML地图 鸿蒙接入高德地图实现POI搜索 在当今数字化时代,地图应用已成为移动设备中不可或缺的一部分。随着鸿蒙系统的日益普及,如何在鸿蒙应用中…

计算机视觉(opencv-python)入门之常见图像处理基本操作(待补充)

图像预处理是计算机视觉任务中的关键步骤,它通过对原始图像进行处理,以提高后续图像分析、特征提取和识别的准确性。 示例图片 目录 常见图像预处理方法 灰度化处理 法一 法二 说明 切片截取部分图像数据 cv2.cvtColor() 颜色空间转换 cv2.spli…

采用DDNS-GO与cloudflare实现双域名同时访问NAS

这个标题其实解释的还不够清楚,本人是小白,但是买了群晖的NAS后自己瞎折腾了一下,遇到了如下的问题: 1、家里是移动宽带,没有公网IP,因此Ipv4无法使用,IPV6可以正常使用。 2、办公室场地采用的…

w803|联盛德|WM IoT SDK2.X测试|pinout|(2):w803开发板简介

概述 W803-Pico是一款基于联盛德W803芯片为主控的开发板,支持IEEE802.11 b/g/n Wi-Fi,以及BT/BLE4.2协议蓝牙。芯片内置高性能32位处理器,主频高达240MHz。内置2MB Flash以及288KB RAM。硬件采用DIP封装,PCB板载天线,…

【UCB CS 61B SP24】Lecture 16 - Data Structures 2: ADTs, BSTs学习笔记

本文首先介绍了抽象数据类型与树的概念,接着重点讲解二叉搜索树的定义与操作方式,并用 Java 实现一个标准的二叉搜索树结构。 1. 抽象数据类型 首先引入一个概念叫做抽象数据类型(Abstract Data Type,ADT)&#xff0…

Java 大视界 -- Java 大数据在智能物流路径规划与车辆调度中的创新应用(102)

💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…

HarmonyOS Design 介绍

HarmonyOS Design 介绍 文章目录 HarmonyOS Design 介绍一、HarmonyOS Design 是什么?1. 设计系统(Design System)2. UI 框架的支持3. 设计工具和资源4. 开发指南5. 与其他设计系统的对比总结 二、HarmonyOS Design 特点 | 应用场景1. Harmon…

【算法系列】快速排序详解

文章目录 快速排序的多种实现方式1. 基本快速排序(Lomuto 分区方案)1.1 基本原理1.2 步骤1.3 Java 实现示例 2. Hoare 分区方案2.1 基本原理2.2 步骤2.3 Java 实现示例 3. 三数取中法3.1 基本原理3.2 步骤3.3 Java 实现示例 4. 尾递归优化4.1 基本原理4.…

电脑键盘知识

1、键盘四大功能区 1. 功能区 2. 主要信息输入区 3. 编辑区 4. 数字键盘区 笔记本电脑键盘的功能区,使用前需先按Fn键 1.1、功能区 ESC:退出 F1:显示帮助信息 F2:重命名 F4:重复上一步操作 F5:刷新网页 …

Grok 3 vs. DeepSeek vs. ChatGPT:2025终极AI对决

2025 年,AI 领域的竞争愈发激烈,三个重量级选手争夺霸主地位:Grok 3(由 xAI 开发)、DeepSeek(国内 AI 初创公司)和 ChatGPT(OpenAI 产品)。每个模型都有自己独特的优势,无论是在深度思考、速度、编程辅助、创意输出,还是在成本控制方面,都展现出强大的实力。但究竟…

【MySQL篇】数据库基础

目录 1,什么是数据库? 2,主流数据库 3,MySQL介绍 1,MySQL架构 2,SQL分类 3,MySQL存储引擎 1,什么是数据库? 数据库(Database,简称DB&#xf…

基于SpringBoot+mybatisplus+vueJS的Cosplay文化展示与交流社区设计与实现

博主介绍:硕士研究生,专注于信息化技术领域开发与管理,会使用java、标准c/c等开发语言,以及毕业项目实战✌ 从事基于java BS架构、CS架构、c/c 编程工作近16年,拥有近12年的管理工作经验,拥有较丰富的技术架…

组件传递props校验

注意&#xff1a;prop是只读的&#xff01;不可以修改父组件的数据。 可以检验传过来的内容是否类型没问题。 App.vue <template><div><!-- <parentDemo/> --><componentA/></div></template> <script> import ComponentA …

数据结构与算法-图论-最短路-拓展运用

选择最佳路线 分析&#xff1a; 这是一道图论中的最短路径问题&#xff0c;目标是在给定的公交网络中&#xff0c;找到从琪琪家附近的车站出发&#xff0c;到她朋友家附近车站&#xff08;编号为 s &#xff09;的最短时间。以下是对该问题的详细分析&#xff1a; 问题关键信息…

0—QT ui界面一览

2025.2.26&#xff0c;感谢gpt4 1.控件盒子 1. Layouts&#xff08;布局&#xff09; 布局控件用于组织界面上的控件&#xff0c;确保它们的位置和排列方式合理。 Vertical Layout&#xff08;垂直布局&#xff09; &#xff1a;将控件按垂直方向排列。 建议&#xff1a;适…