Python-数据爬取(爬虫)

简介: 【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

相关文章
|
28天前
|
数据采集 存储 开发者
如何动态调整Python爬虫的Request请求延迟
如何动态调整Python爬虫的Request请求延迟
|
25天前
|
数据采集 NoSQL 关系型数据库
Python爬虫去重策略:增量爬取与历史数据比对
Python爬虫去重策略:增量爬取与历史数据比对
|
11天前
|
数据采集 Web App开发 前端开发
Python爬虫中time.sleep()与动态加载的配合使用
Python爬虫中time.sleep()与动态加载的配合使用
|
12天前
|
数据采集 存储 NoSQL
分布式爬虫去重:Python + Redis实现高效URL去重
分布式爬虫去重:Python + Redis实现高效URL去重
|
1月前
|
数据采集 存储 监控
Python 原生爬虫教程:网络爬虫的基本概念和认知
网络爬虫是一种自动抓取互联网信息的程序,广泛应用于搜索引擎、数据采集、新闻聚合和价格监控等领域。其工作流程包括 URL 调度、HTTP 请求、页面下载、解析、数据存储及新 URL 发现。Python 因其丰富的库(如 requests、BeautifulSoup、Scrapy)和简洁语法成为爬虫开发的首选语言。然而,在使用爬虫时需注意法律与道德问题,例如遵守 robots.txt 规则、控制请求频率以及合法使用数据,以确保爬虫技术健康有序发展。
206 31
|
28天前
|
数据采集 存储 缓存
Python爬虫与代理IP:高效抓取数据的实战指南
在数据驱动的时代,网络爬虫是获取信息的重要工具。本文详解如何用Python结合代理IP抓取数据:从基础概念(爬虫原理与代理作用)到环境搭建(核心库与代理选择),再到实战步骤(单线程、多线程及Scrapy框架应用)。同时探讨反爬策略、数据处理与存储,并强调伦理与法律边界。最后分享性能优化技巧,助您高效抓取公开数据,实现技术与伦理的平衡。
82 4
|
27天前
|
数据采集 Web App开发 iOS开发
Python 爬虫如何伪装 Referer?从随机生成到动态匹配
Python 爬虫如何伪装 Referer?从随机生成到动态匹配
|
1月前
|
数据采集 Web App开发 文字识别
Python爬虫多次请求后被要求验证码的应对策略
Python爬虫多次请求后被要求验证码的应对策略
|
1月前
|
数据采集 搜索推荐 API
Python 原生爬虫教程:京东商品列表页面数据API
京东商品列表API是电商大数据分析的重要工具,支持开发者、商家和研究人员获取京东平台商品数据。通过关键词搜索、分类筛选、价格区间等条件,可返回多维度商品信息(如名称、价格、销量等),适用于市场调研与推荐系统开发。本文介绍其功能并提供Python请求示例。接口采用HTTP GET/POST方式,支持分页、排序等功能,满足多样化数据需求。
|
1月前
|
数据采集 存储 JSON
用Python爬虫抓取数据并保存为JSON的完整指南
用Python爬虫抓取数据并保存为JSON的完整指南