Python 的网络与互联网访问模块及应用实例(一)
wptr33 2025-09-06 14:05 15 浏览
Python 提供了丰富的内置模块和第三方库来处理网络与互联网访问,使得从简单的 HTTP 请求到复杂的网络通信都变得相对简单。以下是常用的网络模块及其应用实例。
一、常用网络访问模块
socket - 底层网络接口,TCP/UDP 编程
http.client - 提供 HTTP 和 HTTPS 客户端功能
urllib - 处理 URL 和 HTTP 请求
ftplib - FTP 客户端操作
smtplib - 发送电子邮件
poplib - 接收电子邮件(从 POP3 服务器)
imaplib - 接收电子邮件(从 IMAP 服务器)
email - 解析和生成电子邮件
requests - 更简洁、易用的 HTTP 客户端库(第三方)
aiohttp - 异步 HTTP 客户端/服务器框架(第三方)
websockets - WebSocket 客户端/服务器实现(第三方)
paramiko - SSHv2 协议实现(第三方)
twisted - 事件驱动的网络编程框架(第三方)
二、核心模块应用实例
socket 模块:底层网络通信
TCP 服务器示例:
import socket
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server_address = ('localhost', 12345)
server_socket.bind(server_address)
server_socket.listen(5)
print("服务器启动,等待连接...")
while True:
client_socket, client_address = server_socket.accept()
print(f"接收到来自 {client_address} 的连接")
try:
data = client_socket.recv(1024)
print(f"收到数据: {data.decode('utf-8')}")
message = "你好!消息已收到。"
client_socket.sendall(message.encode('utf-8'))
finally:
client_socket.close()
TCP 客户端示例:
import socket
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server_address = ('localhost', 12345)
try:
client_socket.connect(server_address)
message = "Hello, Server!"
client_socket.sendall(message.encode('utf-8'))
data = client_socket.recv(1024)
print(f"服务器响应: {data.decode('utf-8')}")
finally:
client_socket.close()
requests 库:HTTP 客户端
GET 请求示例:
import requests
url = 'https://www.example.com '
response = requests.get(url)
if response.status_code == 200:
print(response.text)
else:
print(f"请求失败,状态码: {response.status_code}")
带参数的 GET 请求:
import requests
url = 'https://api.github.com/search/repositories '
params = {'q': 'python', 'sort': 'stars'}
headers = {'User-Agent': 'Mozilla/5.0'}
try:
response = requests.get(url, params=params, headers=headers, timeout=5)
response.raise_for_status()
data = response.json()
for repo in data['items'][:5]:
print(f"仓库名: {repo['name']}, 星数: {repo['stargazers_count']}")
except requests.exceptions.RequestException as e:
print(f"请求出错: {e}")
smtplib 和 email 模块:发送邮件
发送纯文本邮件:
import smtplib
from email.mime.text import MIMEText
from email.utils import formataddr
sender = 'your_email@example.com '
receiver = 'recipient@example.com '
smtp_pass = 'your_authorization_code'
msg = MIMEText('这是一封用 Python 发送的测试邮件。', 'plain', 'utf-8')
msg['Subject'] = 'Python SMTP 测试邮件'
msg['From'] = formataddr(('发送者名称', sender))
msg['To'] = formataddr(('接收者名称', receiver))
try:
server = smtplib.SMTP_SSL('smtp.qq.com', 465)
server.login(sender, smtp_pass)
server.sendmail(sender, [receiver], msg.as_string())
print("邮件发送成功")
except Exception as e:
print(f"邮件发送失败: {e}")
finally:
server.quit()
ftplib 模块:FTP 操作
from ftplib import FTP
ftp = FTP('ftp.example.com')
ftp.login('username', 'password')
ftp.cwd('/pub/python')
ftp.retrlines('LIST')
with open('local_file.txt', 'wb') as f:
ftp.retrbinary('RETR remote_file.txt', f.write)
with open('file_to_upload.txt', 'rb') as f:
ftp.storbinary('STOR uploaded_file.txt', f)
ftp.quit()
三、错误处理与重试机制
使用 requests 时的错误处理:
import requests
from requests.exceptions import RequestException, Timeout, HTTPError, ConnectionError
url = 'https://www.example.com '
try:
response = requests.get(url, timeout=5)
response.raise_for_status()
print(response.text)
except Timeout:
print("请求超时,请检查网络或稍后重试")
except ConnectionError:
print("网络连接错误,请检查网络设置")
except HTTPError as err:
print(f"HTTP 错误: {err}")
except RequestException as err:
print(f"请求异常: {err}")
简单的重试机制:
import requests
import time
def make_request_with_retry(url, retries=3, delay=1):
for attempt in range(1, retries + 1):
try:
response = requests.get(url, timeout=5)
response.raise_for_status()
return response
except RequestException as e:
print(f"请求失败,第 {attempt} 次尝试: {e}")
if attempt == retries:
print("已达到最大重试次数,放弃请求")
raise
time.sleep(delay)
return None
response = make_request_with_retry('https://www.example.com ')
if response is not None:
print(response.text)
四、简单应用实例:获取本机网络信息
import socket
import tkinter as tk
import tkinter.messagebox
def get_network_info():
try:
hostname = socket.gethostname()
ip_list = socket.gethostbyname_ex(hostname)[2]
return hostname, ip_list
except Exception as e:
print(f"获取网络信息失败: {e}")
return None, []
hostname, ip_list = get_network_info()
print(f"主机名: {hostname}")
print("IP 地址列表:")
for ip in ip_list:
print(f" {ip}")
五、最佳实践与注意事项
异常处理:网络操作极易因各种原因失败,务必使用 try-except 块进行妥善处理
超时设置:几乎所有网络请求都应设置合理的超时时间
资源清理:确保网络连接被正确关闭,防止资源泄漏
安全性:
处理用户输入或从网络接收的数据时需谨慎
使用 HTTPS 等加密协议传输敏感信息
妥善保管 API 密钥、密码等敏感信息
遵守规则:在进行网络爬虫或大量请求时,务必遵守网站的 robots.txt 协议
第三方库:对于常见的 HTTP 请求,优先考虑使用 requests 库而非 urllib
相关推荐
- [常用工具] git基础学习笔记_git工具有哪些
-
添加推送信息,-m=messagegitcommit-m“添加注释”查看状态...
- centos7安装部署gitlab_centos7安装git服务器
-
一、Gitlab介1.1gitlab信息GitLab是利用RubyonRails一个开源的版本管理系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。...
- 太高效了!玩了这么久的Linux,居然不知道这7个终端快捷键
-
作为Linux用户,大家肯定在Linux终端下敲过无数的命令。有的命令很短,比如:ls、cd、pwd之类,这种命令大家毫无压力。但是,有些命令就比较长了,比如:...
- 提高开发速度还能保证质量的10个小窍门
-
养成坏习惯真是分分钟的事儿,而养成好习惯却很难。我发现,把那些对我有用的习惯写下来,能让我坚持住已经花心思养成的好习惯。...
- 版本管理最好用的工具,你懂多少?
-
版本控制(Revisioncontrol)是一种在开发的过程中用于管理我们对文件、目录或工程等内容的修改历史,方便查看更改历史记录,备份以便恢复以前的版本的软件工程技术。...
- Git回退到某个版本_git回退到某个版本详细步骤
-
在开发过程,有时会遇到合并代码或者合并主分支代码导致自己分支代码冲突等问题,这时我们需要回退到某个commit_id版本1,查看所有历史版本,获取git的某个历史版本id...
- Kubernetes + Jenkins + Harbor 全景实战手册
-
Kubernetes+Jenkins+Harbor全景实战手册在现代企业级DevOps体系中,Kubernetes(K8s)、Jenkins和Harbor组成的CI/CD流水...
- git常用命令整理_git常见命令
-
一、Git仓库完整迁移完整迁移,就是指,不仅将所有代码移植到新的仓库,而且要保留所有的commit记录1.随便找个文件夹,从原地址克隆一份裸版本库...
- 第三章:Git分支管理(多人协作基础)
-
3.1分支基本概念分支是Git最强大的功能之一,它允许你在主线之外创建独立的开发线路,互不干扰。理解分支的工作原理是掌握Git的关键。核心概念:HEAD:指向当前分支的指针...
- 云效Codeup怎么创建分支并进行分支管理
-
云效Codeup怎么创建分支并进行分支管理,分支是为了将修改记录分叉备份保存,不受其他分支的影响,所以在同一个代码库里可以同时进行多个修改。创建仓库时,会自动创建Master分支作为默认分支,后续...
- git 如何删除本地和远程分支?_git怎么删除远程仓库
-
Git分支对于开发人员来说是一项强大的功能,但要维护干净的存储库,就需要知道如何删除过时的分支。本指南涵盖了您需要了解的有关本地和远程删除Git分支的所有信息。了解Git分支...
- git 实现一份代码push到两个git地址上
-
一直以来想把自己的博客代码托管到github和coding上想一次更改一次push两个地址一起更新今天有空查资料实践了下本博客的github地址coding的git地址如果是Gi...
- git操作:cherry-pick和rebase_git cherry-pick bad object
-
在编码中经常涉及到分支之间的代码同步问题,那就需要cherry-pick和rebase命令问题:如何将某个分支的多个commit合并到另一个分支,并在另一个分支只保留一个commit记录解答:假设有两...
- 模型文件硬塞进 Git,GitHub 直接打回原形:使用Git-LFS管理大文件
-
前言最近接手了一个计算机视觉项目代码是屎山就不说了,反正我也不看代码主要就是构建一下docker镜像,测试一下部署的兼容性这本来不难但是,国内服务器的网络环境实在是恶劣,需要配置各种镜像(dock...
- 防弹少年团田柾国《Euphoria》2周年 获世界实时趋势榜1位 恭喜呀
-
当天韩国时间凌晨3时左右,该曲在Twitter上以“2YearsWithEuphoria”的HashTag登上了世界趋势1位。在韩国推特实时趋势中,从上午开始到现在“Euphoria2岁”的Has...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
Java面试必考问题:什么是乐观锁与悲观锁
-
如何将AI助手接入微信(打开ai手机助手)
-
SparkSQL——DataFrame的创建与使用
-
redission YYDS spring boot redission 使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)