Python-数据爬取(爬虫)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介: 【7月更文挑战第24天】

1.简要描述一下Python爬虫的工作原理,并介绍几个常用的Python爬虫库。
Python爬虫的工作原理
发送请求:爬虫向目标网站发送HTTP请求,通常使用GET请求来获取网页内容。
解析响应:接收并解析HTTP响应,提取出有用的数据。常用的解析方式包括HTML解析和JSON解析。
数据提取:使用解析后的数据,根据特定的规则或结构,提取所需信息。
数据存储:将提取出的数据保存到文件、数据库或其他存储系统中。
遵守规则:爬虫需要遵守目标网站的robots.txt文件中的规则,避免对服务器造成过大压力。
常用的Python爬虫库
Requests:一个简单易用的HTTP库,用于发送请求和接收响应。
BeautifulSoup:一个用于解析HTML和XML的库,可以轻松地提取网页中的数据。
Scrapy:一个功能强大的爬虫框架,提供了许多高级功能,如请求调度、数据提取和存储。
Selenium:用于模拟浏览器操作,适合处理需要JavaScript渲染的网页。
使用selenium库爬取东方财富网站股票数据信息

示例代码和过程说明
安装Selenium库:首先确保已经安装了Selenium库和对应的浏览器驱动,例如Chrome驱动(Chrome WebDriver)。

pip install selenium
导入必要的库和设置:导入Selenium库,并设置浏览器驱动的路径和目标网页URL。

from selenium import webdriver
import time

设置 Chrome 驱动程序路径

driver_path = '/path/to/chromedriver'

目标网页 URL

url = 'http://quote.eastmoney.com/center/gridlist.html#hs_a_board'
设置浏览器选项和启动WebDriver:配置Chrome浏览器选项,启动WebDriver,并打开目标网页。

设置 Chrome 浏览器选项

options = webdriver.ChromeOptions()
options.add_argument('--headless') # 无头模式运行浏览器,即不打开实际浏览器窗口
options.add_argument('--disable-gpu')
options.add_argument('--no-sandbox')

启动 Chrome 浏览器

driver = webdriver.Chrome(executable_path=driver_path, options=options)

打开目标网页

driver.get(url)
模拟翻页和数据抓取:使用Selenium模拟点击下一页按钮,然后等待2秒钟加载下一页数据,并抓取页面中的股票数据。

try:
while True:

    # 等待页面加载完全
    time.sleep(2)

    # 爬取当前页面数据(这里假设抓取表格数据的过程)
    table = driver.find_element_by_css_selector('table.stock-table')

    # 处理表格数据,例如输出或者存储数据
    rows = table.find_elements_by_css_selector('tr')
    for row in rows:
        # 处理每一行数据,例如打印股票代码和名称
        cells = row.find_elements_by_css_selector('td')
        if len(cells) >= 2:
            stock_code = cells[0].text
            stock_name = cells[1].text
            print(f"股票代码: {stock_code}, 股票名称: {stock_name}")

    # 查找并点击下一页按钮
    next_button = driver.find_element_by_css_selector('a.next')
    next_button.click()

except Exception as e:
print(f"爬取过程出现异常: {str(e)}")

finally:

# 关闭浏览器驱动
driver.quit()

源码
from selenium import webdriver
import time

设置 Chrome 驱动程序路径

driver_path = '/path/to/chromedriver'

目标网页 URL

url = 'http://quote.eastmoney.com/center/gridlist.html#hs_a_board'

设置 Chrome 浏览器选项

options = webdriver.ChromeOptions()
options.add_argument('--headless') # 无头模式运行浏览器,即不打开实际浏览器窗口
options.add_argument('--disable-gpu')
options.add_argument('--no-sandbox')

启动 Chrome 浏览器

driver = webdriver.Chrome(executable_path=driver_path, options=options)

try:

# 打开目标网页
driver.get(url)

while True:
    # 等待页面加载完全
    time.sleep(2)

    # 爬取当前页面数据(这里假设抓取表格数据的过程)
    table = driver.find_element_by_css_selector('table.stock-table')

    # 处理表格数据,例如输出或者存储数据
    rows = table.find_elements_by_css_selector('tr')
    for row in rows:
        # 处理每一行数据,例如打印股票代码和名称
        cells = row.find_elements_by_css_selector('td')
        if len(cells) >= 2:
            stock_code = cells[0].text
            stock_name = cells[1].text
            print(f"股票代码: {stock_code}, 股票名称: {stock_name}")

    # 查找并点击下一页按钮
    next_button = driver.find_element_by_css_selector('a.next')
    next_button.click()

except Exception as e:
print(f"爬取过程出现异常: {str(e)}")

finally:

# 关闭浏览器驱动
driver.quit()

过程说明
设置浏览器选项和启动WebDriver:通过设置ChromeOptions来配置Chrome浏览器的参数,包括无头模式等,然后启动Chrome浏览器。

模拟翻页和数据抓取:使用一个while循环,不断查找并点击页面的下一页按钮(假设为CSS选择器a.next),然后等待2秒钟(使用time.sleep(2))加载下一页数据。在每一页加载完成后,使用Selenium的方法找到表格元素(假设为CSS选择器table.stock-table),然后逐行抓取并处理股票数据。

异常处理和浏览器关闭:使用try-except语句捕获可能出现的异常,并在最后通过driver.quit()关闭浏览器驱动,确保资源释放。

2.Scrapy 框架的基本结构和工作流程是怎样的?
Scrapy 框架的基本结构
项目结构:Scrapy项目包含多个文件和目录,如spiders(存放爬虫代码)、items(定义数据结构)、pipelines(处理提取的数据)、settings(项目配置)等。
Spiders:定义爬虫的核心部分,负责发送请求和解析响应。
Items:定义数据结构,用于存储爬取的数据。
Pipelines:处理提取的数据,可以进行清洗、验证和存储等操作。
Middlewares:中间件,用于处理请求和响应的过程,类似于过滤器。
Scrapy 工作流程
启动爬虫:Scrapy启动后,加载配置和爬虫类。
发送请求:爬虫类发送初始请求(通常是start_urls列表中的URL)。
解析响应:收到响应后,调用爬虫类中的解析方法(如parse),提取数据和生成新的请求。
生成新的请求:解析方法可以生成新的请求,这些请求会被放入调度器中,等待执行。
处理数据:提取到的数据会被传递到pipelines进行进一步处理,如清洗和存储。
Scrapy 示例
下面是一个简单的Scrapy爬虫示例,它爬取一个示例网站的标题和链接。

创建Scrapy项目:

scrapy startproject example
定义数据结构(example/items.py):

import scrapy

class ExampleItem(scrapy.Item):
title = scrapy.Field()
link = scrapy.Field()
创建爬虫类(example/spiders/example_spider.py):

import scrapy
from example.items import ExampleItem

class ExampleSpider(scrapy.Spider):
name = "example"
start_urls = ['http://example.com']

def parse(self, response):
    for item in response.css('div.item'):
        example_item = ExampleItem()
        example_item['title'] = item.css('a.title::text').get()
        example_item['link'] = item.css('a::attr(href)').get()
        yield example_item

配置pipelines(example/settings.py):

ITEM_PIPELINES = {
'example.pipelines.ExamplePipeline': 300,
}
定义pipelines(example/pipelines.py):

class ExamplePipeline:
def process_item(self, item, spider):

    # 这里可以进行数据清洗和存储
    print(f"Title: {item['title']}, Link: {item['link']}")
    return item

运行爬虫:

scrapy crawl example
这个爬虫会访问http://example.com,提取每个div.item中的标题和链接,并将其输出。
原文链接:https://blog.csdn.net/m0_74940474/article/details/140381034

相关文章
|
5天前
|
数据采集 JSON 算法
Python爬虫——模拟登录
Python爬虫——模拟登录
43 3
|
5天前
|
数据采集 JSON 算法
Python爬虫——基于JWT的模拟登录爬取实战
Python爬虫——基于JWT的模拟登录爬取实战
21 1
Python爬虫——基于JWT的模拟登录爬取实战
|
6天前
|
JSON 安全 数据安全/隐私保护
深度剖析:Python如何运用OAuth与JWT,为数据加上双保险🔐
【10月更文挑战第2天】当讨论Web应用安全时,认证与授权至关重要。OAuth 2.0 和 JSON Web Tokens (JWT) 是现代Web应用中最流行的两种认证机制。OAuth 2.0 是一种开放标准授权协议,允许资源拥有者授予客户端访问资源的权限,而不需直接暴露凭据。JWT 则是一种紧凑、URL 安全的信息传输方式,自我包含认证信息,无需服务器查询数据库验证用户身份。在 Python 中,Flask-OAuthlib 和 PyJWT 分别用于实现 OAuth 2.0 和 JWT 的功能。结合两者可构建高效且安全的认证体系,提高安全性并简化交互过程,为数据安全提供双重保障。
18 7
|
1天前
|
数据采集 缓存 Java
Python vs Java:爬虫任务中的效率比较
Python vs Java:爬虫任务中的效率比较
|
4天前
|
数据采集 存储 监控
如何使用 Python 爬取商品数据
如何使用 Python 爬取京东商品数据
20 3
|
4天前
|
数据采集 机器学习/深度学习 数据挖掘
数据也需SPA?Python转换大法,给你的数据做个全身放松SPA!
【10月更文挑战第4天】在数字化时代,数据犹如企业的血液,贯穿于各项业务之中。就像人需要定期SPA恢复活力,数据也需要“转换大法”来优化结构和提升质量,从而更好地支持决策分析与机器学习。本文探讨了如何使用Python进行数据SPA,包括理解需求、数据清洗、格式转换及聚合分析等步骤。通过Python强大的Pandas库,我们可以轻松完成缺失值填充、重复记录删除等任务,并实现数据格式的标准化,确保数据更加整洁、有序,助力高效分析与决策。为企业数据注入新的活力,迎接更多挑战。
10 1
|
4天前
|
数据采集 存储 监控
如何使用 Python 爬取京东商品数据
如何使用 Python 爬取京东商品数据
17 2
|
5天前
|
数据采集 前端开发 NoSQL
Python编程异步爬虫实战案例
Python编程异步爬虫实战案例
15 2
|
5天前
|
消息中间件 数据采集 数据库
小说爬虫-03 爬取章节的详细内容并保存 将章节URL推送至RabbitMQ Scrapy消费MQ 对数据进行爬取后写入SQLite
小说爬虫-03 爬取章节的详细内容并保存 将章节URL推送至RabbitMQ Scrapy消费MQ 对数据进行爬取后写入SQLite
12 1
|
1天前
|
机器学习/深度学习 TensorFlow 算法框架/工具
使用Python实现深度学习模型:智能数据隐私保护
使用Python实现深度学习模型:智能数据隐私保护 【10月更文挑战第3天】
10 0