用python抓取网页数据的基础方法

引言

在数据科学和网络爬虫领域,网页抓取是一项关键技术。Python凭借其丰富的第三方库,能够高效地简化网页解析与数据提取流程,已成为该领域的流行选择。本文将介绍几种常见的网页抓取方法,供需要的读者参考。

1. 使用 requests 和 BeautifulSoup 进行网页抓取

1.1 安装依赖

你需要安装 requests 和 beautifulsoup4 库。这两个库分别用于网页请求和网页解析。

python 复制代码
pip install requests beautifulsoup4

1.2 确保网络畅通,能够访问目标网站

1.3 基本用法

python 复制代码
import requests
from bs4 import BeautifulSoup

# 目标网页URL
url = 'https://www.example.com'

# 请求头,模拟浏览器访问,避免被反爬
headers = {
    "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36",
    "Referer": "https://www.example.com",
    "Accept-Language": "zh-CN,zh;q=0.9,en;q=0.8"
}

# 发送HTTP请求
response = requests.get(url, headers=headers, timeout=10)
# response.raise_for_status()  # 抛出HTTP请求异常
response.encoding = "utf-8"  # 设置编码

# 检查请求是否成功
if response.status_code == 200:
    # 解析HTML内容
    soup = BeautifulSoup(response.text, 'html.parser')

    # 找到页面中的标题(<title>标签)
    title = soup.find('title').text
    print('页面标题:', title)
    # 找到特定div的内容
    divs = soup.find_all('article',class_='blog-list-box')
    # 得到一个集合
    print(divs[0])
    # 根据具体需要,我们可以获取不同html标签的内容,进行显示或者存储操作
else:
    print('请求失败,状态码:', response.status_code)

1.4 总结

总之,Python 提供了多种强大的网页抓取方法,适用于不同类型的网页。requests 和 BeautifulSoup 是最基础的组合,适合静态网页的抓取,后续还需总结其他复杂网页、使用框架抓取网页的方法,文档带进一步完善。

相关推荐
gcfer14 小时前
Python基础语法记录
python
zfj32114 小时前
从源码层面解析一下ThreadLocal的工作原理
java·开发语言·threadlocal
墨笔之风14 小时前
java后端根据双数据源进行不同的接口查询
java·开发语言·mysql·postgres
Mr -老鬼14 小时前
功能需求对前后端技术选型的横向建议
开发语言·前端·后端·前端框架
IT=>小脑虎14 小时前
Go语言零基础小白学习知识点【基础版详解】
开发语言·后端·学习·golang
qq_4061761414 小时前
关于JavaScript中的filter方法
开发语言·前端·javascript·ajax·原型模式
爬山算法15 小时前
Hibernate(32)什么是Hibernate的Criteria查询?
java·python·hibernate
醇氧15 小时前
Ping 127.0.0.1 具有 32 字节的数据:一般故障。【二】
运维·服务器·开发语言
码农水水15 小时前
中国邮政Java面试:热点Key的探测和本地缓存方案
java·开发语言·windows·缓存·面试·职场和发展·kafka