【Python爬虫】详细工作流程以及组成部分
目录
一、Python爬虫的详细工作流程
确定起始网页
发送 HTTP 请求
解析 HTML
处理数据
跟踪链接
递归抓取
存储数据
二、Python爬虫的组成部分
请求模块
解析模块
数据处理模块
存储模块
调度模块
反爬虫处理模块
一、Python爬虫的详细工作流程
在进行网络爬虫工作时,以下是其核心的工作流程及相应的详细操作步骤:
确定起始网页
首先,需要精心挑选一个或多个合适的起始网页,它们将作为整个爬虫程序开始抓取数据的关键入口点。这些起始网页的选择往往基于爬虫的目标和需求,例如,若要采集某类新闻资讯,可选取该领域知名新闻网站的首页或者特定频道的首页作为起始网页;若聚焦于电商商品信息,则可将大型电商平台的分类商品列表页作为起始点。
发送 HTTP 请求
选好起始网页后,爬虫便会模拟浏览器的行为,向这些起始网页所在服务器发送 HTTP 请求。这个过程如同我们在浏览器地址栏输入网址并回车获取网页内容一样,只不过爬虫是通过代码来实现这一操作。借助相应的网络请求库(如requests
),爬虫能够获取到网页的原始 HTML 代码,这是后续解析和提取数据的基础素材。
解析 HTML
获取到 HTML 代码后,爬虫会运用专业的 HTML 解析工具来深入剖析这些代码内容。
常见且实用的解析器有Beautiful Soup
,它提供了便捷且功能强大的方法,能按照 HTML 标签、属性、类名等元素精准定位到所需数据所在位置;另外,正则表达式也可用于对 HTML 代码进行解析,尤其适用于一些具有特定格式规律的数据提取场景。
通过这些解析手段,爬虫可以从繁杂的 HTML 代码中挖掘出各类有用的数据,像页面中的文本信息、展示的图片链接以及指向其他页面的超链接等。
处理数据
从 HTML 代码中提取出的数据往往还处于较为原始、杂乱的状态,需要进一步对其进行处理、清洗和整理。例如,提取的文本可能包含多余的空格、换行符或者一些特殊字符,此时就需要通过编写代码去除这些不必要的内容,使其格式规范统一;对于图片链接,可能需要检查其有效性,并根据后续存储和分析的需求进行相应的格式转换等操作。经过这样的处理过程,数据才能更便于后续的存储以及各类分析工作开展。
跟踪链接
在解析当前网页的 HTML 代码时,爬虫会从中提取出众多指向其他页面的链接,这些链接蕴含着拓展数据采集范围的潜力。爬虫会把这些链接有序地添加到待抓取列表中,然后依据预先设定好的抓取策略,例如按照链接的重要性排序、深度优先或者广度优先等策略,从中选择下一个要抓取的链接,从而为进一步深入挖掘更多网页数据做好准备。
递归抓取
依托上述的操作流程,爬虫会以递归的方式持续工作。即不断重复发送 HTTP 请求、解析 HTML、处理数据以及跟踪链接这些步骤,持续抓取新的网页,并从中提取出有价值的数据。这一过程会循环往复地进行,直至满足特定的停止条件。
停止条件可能是达到了预先设定的抓取深度,比如规定只抓取三层页面链接内的数据;或者是抓取的网页数量达到了既定目标;亦或是遇到了如特定页面提示 “无更多内容” 之类的指定终止条件,以此确保爬虫工作在合理的范围内有序完成。
存储数据
在整个抓取过程中,爬虫会将获取到的各类数据妥善保存起来,以便后续进行深入的使用和分析。
存储的介质可以是多样化的,例如将数据存储到关系型数据库(如 MySQL、Oracle 等)中,方便进行复杂的查询和数据关联操作;也可以保存到非关系型数据库(如 MongoDB 等),以应对数据结构较为灵活、复杂的情况;还能将数据写入到本地文件(如 CSV 文件便于数据分析、JSON 文件利于数据交换等)中,根据具体的使用场景和需求选择最为合适的存储方式。
通过这样一套严谨且有序的流程,网络爬虫能够高效、准确地从互联网上抓取到大量有价值的数据,为后续的各类应用和分析提供有力的数据支撑。
二、Python爬虫的组成部分
Python 爬虫主要由以下几个核心部分组成:
请求模块
该模块的主要功能是,负责向目标网站发送 HTTP 请求,以获取网页的原始内容。HTTP 请求有多种类型,如 GET、POST 等,爬虫可根据不同的需求选择合适的请求类型。
import requests# 发送GET请求
response = requests.get('https://www.example.com')
if response.status_code == 200:print(response.text)
解析模块
该模块的主要功能是,对请求模块获取到的网页内容(通常是 HTML、XML 或 JSON 格式)进行解析,从中提取出所需的数据。
常用库:
-
BeautifulSoup:是一个强大的 HTML/XML 解析库,能将复杂的 HTML 或 XML 文档转换为树形结构,方便用户通过标签名、类名、ID 等属性查找和提取数据。
-
request:这是一个简洁且功能强大的 HTTP 库,它使得发送 HTTP 请求变得异常简单,支持多种请求方法(如 GET、POST 等),还能处理请求头、请求参数、Cookie 等。
-
lxml:是一个高性能的 XML 和 HTML 解析器,解析速度快,功能强大。
from bs4 import BeautifulSoup
import requestsresponse = requests.get('https://www.example.com')
soup = BeautifulSoup(response.text, 'html.parser')
links = soup.find_all('a') # 查找所有的<a>标签
for link in links:print(link.get('href'))
数据处理模块
该模块的主要功能是,对解析模块提取的数据进行清洗、转换和整理,使其符合后续存储或分析的要求。例如,去除数据中的多余空格、特殊字符,将数据转换为统一的格式等。
# 去除字符串中的多余空格 cleaned_data = " hello, world! ".strip()
存储模块
该模块的主要功能是,将处理好的数据保存到合适的存储介质中,以便后续使用。常见的存储介质包括文件(如 CSV、JSON、TXT 等)、数据库(如 MySQL、MongoDB、Redis 等)。
import csv
data = [['Name', 'Age'],['Alice', 25],['Bob', 30]]with open('data.csv', 'w', newline='') as csvfile:writer = csv.writer(csvfile)writer.writerows(data)
import pymysql# 连接数据库
conn = pymysql.connect(host='localhost', user='root', password='password', database='test')
cursor = conn.cursor()# 创建表
create_table_sql = "CREATE TABLE IF NOT EXISTS users (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(255), age INT)"
cursor.execute(create_table_sql)# 插入数据
insert_sql = "INSERT INTO users (name, age) VALUES (%s, %s)"
data = [('Alice', 25), ('Bob', 30)]
cursor.executemany(insert_sql, data)# 提交事务
conn.commit()# 关闭连接
cursor.close()
conn.close()
调度模块
该模块的主要功能是,负责管理爬虫的任务调度,包括确定抓取的起始页面、控制抓取的顺序和频率、处理待抓取的 URL 队列等。对于大规模的爬虫项目,调度模块还需要考虑分布式爬取和并发控制,以提高爬取效率。
-
Scrapy
是一个功能强大的 Python 爬虫框架,它内置了调度模块,提供了高效的任务调度和并发控制机制。
以下是一个简单的 Scrapy 爬虫示例:
import scrapyclass ExampleSpider(scrapy.Spider):name = 'example'start_urls = ['https://www.example.com']def parse(self, response):# 提取数据links = response.css('a::attr(href)').getall()for link in links:yield {'link': link}
反爬虫处理模块
该模块的主要功能是,在爬虫过程中,目标网站可能会采取各种反爬虫措施,如 IP 封禁、验证码、请求频率限制等。反爬虫处理模块的作用是识别和应对这些反爬虫机制,确保爬虫能够正常运行。
常用方法:
-
使用代理 IP:通过代理服务器隐藏真实 IP 地址,避免被目标网站封禁。可以使用第三方代理服务或自己搭建代理池。
-
设置请求头:模拟浏览器的请求头信息,使爬虫的请求看起来更像正常的浏览器请求。
-
控制请求频率:合理设置请求间隔时间,避免过于频繁的请求触发目标网站的反爬虫机制。
综上所述,一个完整的 Python 爬虫系统需要各个组成部分协同工作,以实现高效、稳定地从互联网上抓取所需的数据。
相关文章:
【Python爬虫】详细工作流程以及组成部分
目录 一、Python爬虫的详细工作流程 确定起始网页 发送 HTTP 请求 解析 HTML 处理数据 跟踪链接 递归抓取 存储数据 二、Python爬虫的组成部分 请求模块 解析模块 数据处理模块 存储模块 调度模块 反爬虫处理模块 一、Python爬虫的详细工作流程 在进行网络爬虫工…...
深入解析UML图:版本演变、静态图与动态图详解
目录 前言1 UML的版本演变1.1 UML 1.x阶段:统一的开始1.2 UML 2.x阶段:功能的扩展与深化 2 UML图的分类概述3 UML静态图详解3.1 类图(Class Diagram)3.2 对象图(Object Diagram)3.3 组件图(Comp…...
老旧测试用例生成平台异步任务与用户通知优化
在现代 Web 开发中,异步任务处理和用户通知是两个重要的功能。由于老旧测试平台【测试用例生成平台,源码分享】进行智能化升级后,未采用异步任务处理,大模型推理时间较长,导致任务阻塞,无法处理其他任务&am…...
数据结构初阶:队列
本篇博客主要讲解队列的相关知识。 目录 1.队列 1.1 概念与结构 1.2 队列头文件(Queue.h) 1.2.1 定义队列结点结构 1.2.2 定义队列的结构 1.3 队列源代码(Queue.h) 1.3.1 队列的初始化 1.3.2 队列的销毁 1.3.3 入队---队尾 1…...
苍穹外卖。12 数据统计
12.1 工作台 12.1.1 需求分析与设计 12.1.2 代码导入 12.1.3 测试 测试通过 12.2 Apache POI 12.2.1 需求分析与设计 12.2.2 案例 column表示索引行...
WebSocket 和 HTTP长轮询
一、HTTP长轮询(Long Polling) 1. 工作原理 传统轮询(低效):客户端每隔几秒向服务器发一次请求,问“有新数据吗?”,即使服务器没有数据也会立即返回“无”。长轮询(改进…...
高等数学同步测试卷 同济7版 试卷部分 上 做题记录 第三章微分中值定理与导数的应用同步测试卷 B 卷
第三章微分中值定理与导数的应用同步测试卷 B 卷 一、单项选择题(本大题共5小题,每小题3分,总计15分) 1. 2. 3. 4. 5. 二、填空题(本大题共5小题,每小题3分,总计15 分) 6. 7. 8. 9. 10. 三、求解下列各题(本大题共5小题,每小题6分,总计 3…...
生成式引擎优化(GEO)发展史与行业标准演变
一、生成式引擎优化(GEO)发展史与行业标准演变 随着 ChatGPT、Bard、Claude、文心一言等生成式AI搜索产品快速发展,GEO(Generative Engine Optimization,生成式引擎优化)也应运而生,成为继SEO、…...
美客多自养号测评技术解析:如何低成本打造安全稳定的测评体系
美客多(MercadoLibre)自养号测评系统的搭建需综合考虑硬件、软件、网络环境及操作流程的合规性,以下是基于多篇行业指南整理的核心步骤与要点: 一、前期规划与准备 1. 明确目标与规则 • 确定测评目的(如提升产品曝…...
STM32单片机入门学习——第36节: [11-1] SPI通信协议
写这个文章是用来学习的,记录一下我的学习过程。希望我能一直坚持下去,我只是一个小白,只是想好好学习,我知道这会很难,但我还是想去做! 本文写于:2025.04.14 STM32开发板学习——第36节: [11-1] SPI通信协议 前言开发板说明引用解答和科普一…...
Qt QML - qmldir使用方法详解
以实际例子看qmldir的使用 1.搞一个qmldir2.让QML找到你的qmldir (重点).pro 工程文件QQmlApplicationEngine加载主QML处 3.用起来你的模块 qmldir是Qt QML模块化的基石,其设计初衷是为解决QML文件的组织、复用和依赖管理问题,。只需要在每个…...
AI大模型赋能工业制造:智能工厂的全新跃迁路径
📝个人主页🌹:一ge科研小菜鸡-CSDN博客 🌹🌹期待您的关注 🌹🌹 引言:从自动化到智造化,工业领域的AI革命正悄然发生 在过去几十年中,制造业经历了机械化、电气化和自动化三次浪潮。如今,第四次工业革命——以人工智能、大数据、云计算、物联网为代表的“工业…...
LanDiff:赋能视频创作,语言与扩散模型的融合力量
自从 Wan 2.1 发布以来,AI 视频生成领域似乎进入了一个发展瓶颈期,但这也让人隐隐感到:“DeepSeek 时刻”即将到来!就在前几天,浙江大学与月之暗面联合推出了一款全新的文本到视频(T2V)生成模型…...
Windows 图形显示驱动开发-WDDM 1.2功能~显示设备的容器id支持
容器 ID 设备驱动程序接口 (DDI) 在显示微型端口驱动程序中实现此函数和结构: DxgkDdiGetChildContainerIdDXGK_CHILD_CONTAINER_ID 容器 ID 说明 监视设备中的新功能可以提供更好的用户体验。 具体而言,通用串行总线 (USB) 集线器是监视器上用于连…...
基于PyQt5和OpenCV的传统图像分割应用UI程序
目录 1. 程序概述 2. 用户界面设计 主窗口布局 图像显示区域 控制面板区域 3. 核心功能实现 图像处理功能 关键方法 4. 特色实现 区域生长算法改进 分水岭算法改进 GrabCut算法改进 5. 用户体验优化 6. 技术栈 7. 使用说明 8. 完整代码 9. 测试结果 本文实现了…...
java使用HTTP实现多线程爬取数据
Java中使用HTTP多线程爬取数据。首先,我得理解他们的需求。可能想要高效地抓取大量网页数据,而单线程可能不够快,所以需要多线程来提高效率。不过,多线程爬虫需要考虑的问题挺多的,比如线程安全、请求频率控制、异常处…...
08【基础学习】串口通信(三):收发数据包+数据校验
收发数据包数据校验 1、和校验异或校验1.1、HEX固定长度数据包校验1.2、HEX不固定长度数据包校验 2、CRC校验 1、和校验异或校验 和校验:将接收到的数据全部相加后,取结果的最后一个字节的数据 异或校验:将接收到的数据全部相异或后ÿ…...
已开源!CMU提出NavRL :基于强化学习的无人机自主导航和动态避障新方案
导读在无人机技术快速发展的今天,如何确保无人机在复杂动态环境中的安全飞行成为一个关键挑战。传统的导航方法通常将决策过程分解为预测和规划两个独立模块,这种手工设计的系统虽然在特定环境中表现良好,但当环境条件发生变化时,…...
C++ (类的设计,对象的创建,this指针,构造函数)
类的设计 C对结构体是有增强的 可以包含函数作为结构体成员 可以直接定义变量 在结构体成员函数里面可以直接访问结构体成员变量 struct student{string name;int age;float score;void play_game(const string &name);}void student::play_game(const string game){}…...
【C++】——lambda表达式
🌟 前言:C Lambda表达式,当函数开始"叛逆期" 你是否有过这样的崩溃瞬间? 为了写个只用到一次的排序规则,被迫定义了一个类在std::for_each里塞函数指针,代码瞬间变成"古董级"写法看着层的循环…...
DHCP简单例子
本文描述了使用ENsp模拟DHCP Global和DHCP 中继两种简单配置过程。 拓朴图 DHCP全局配置 此配置较为简单,因为全局既支持局域网,也支持跨网络分配。 # DHCP Server1 <Huawei>system-view [Huawei]sysname server1 [server1]dhcp enable …...
Spark-SQL简介及核心编程
Spark-SQL概述:是Spark用于结构化数据处理的模块,前身是Shark。Shark基于Hive开发,使SQL-on-Hadoop性能大幅提升,但对Hive依赖制约了Spark发展。SparkSQL汲取Shark优点并重新开发,在数据兼容、性能优化和组件扩展上优势…...
LDAP渗透测试
LDAP渗透测试 1.LDAP协议概述2.LDAP写公钥3.暴力破解LDAP4.LDAP信息收集ldapdomaindumpwindapsearch工具ldapsearch 1.LDAP协议概述 LDAP(Lightweight Directory Access Protocol,轻量目录访问协议)是一种访问和管理目录服务的应用层协议&am…...
观察者模式(行为模式)
观察者模式 观察者模式属于行为模式,个人理解:和发布订阅者魔模式是有区别的 细分有两种:推模式和拉模式两种,具体区别在于推模式会自带推送参数,拉模式是在接收通知后要自己获取更新参数 观察者模式(Obs…...
Spark SQL
Spark SQL Spark SQL 是 Spark 用于结构化数据(structured data)处理的 Spark 模块。 Spark SQL特点 易整合。无缝的整合了 SQL 查询和 Spark 编程 统一的数据访问。使用相同的方式连接不同的数据源 兼容 Hive。在已有的仓库上直接运行 SQL 或者 HQL 标准数据连接。通过 JDBC…...
周末学习笔记:Python文件操作(结构化数据转换与文件处理)
目录 一、任务目标 二、实现步骤与代码解析 2.1 数据准备阶段 关键点解析: 2.2 数据转换核心代码 三、关键技术解析 3.1 字符串处理方法 3.2 数据结构转换 3.3 文件写入技巧 四、执行结果验证 输入文件t1.txt内容: 输出文件t2.txt内容&am…...
【PCIE736-0】基于 PCIE X16 总线架构的 4 路 QSFP28 100G 光纤通道处理平台
产品概述 PCIE736-0 是一款基于 PCIE 总线架构的 4 路 QSFP28 100G 光纤通道适配器,该板卡具有 1 个 PCIe Gen3x16 主机接口、一共 4个 QSFP28 100G 光纤接口,可以实现 4 路 QSFP28 100G 光纤的数据实时采集、实时缓存与 PCIE 高速传输。该板卡采用 Xil…...
PyCharm 开发工具 修改背景颜色
PyCharm 开发工具 修改背景颜色 提示:帮帮志会陆续更新非常多的IT技术知识,希望分享的内容对您有用。本章分享的是Python基础语法。前后每一小节的内容是有学习/理解关联性,希望对您有用~ PyCharm 开发工具 修改背景颜色 文章目录 PyCharm 开…...
linux Shell编程之循环语句(三)
目录 一. for 循环语句 1. for语句的结构 2. for 语句应用示例 (1) 根据姓名列表批量添加用户 (2) 根据 IP 地址列表检查主机状态 二. 使用 while 循环语句 1. while 语句的结构 2. while 语句应用示例 (1) 批量添加规律编号的用户 (2) 猜价格游戏 三. until 循环语…...
GCC和GDB基础知识
1 GCC和G 一套开源的编译器,支持 C、C、Fortran 等语言。它负责将人类编写的源代码(如 .c 文件)翻译成计算机能执行的二进制文件(如 .exe)。 核心作用: 预处理:处理宏…...
网络复习二(TCP【3】)
一、为什么TIME_WAIT等待的时间是2MSL? MSL:报文最大生存时间 我们要知道TCP报文是基于IP协议生存的,而在IP头中有一个TTL(经过路由跳数),当TTL为0使,数据报被丢失,同时发送ICMP报…...
【5G通信】通过RRC重配实现功率调整的可能性
在5G网络中,通过解析UE Capability Information消息中的RF Parameters字段实现终端发射功率的动态调整,需要结合协议规范、射频特性及网络控制策略。以下是技术实现流程及示例: 一、RF Parameters关键字段解析 根据3GPP TS 38.331和TS 38.10…...
UE 使用事件分发器设计程序
【双字精译】虚幻引擎中的设计模式:观察者模式——Ali Elzoheiry|游戏开发游戏编程模式游戏设计模式虚幻蓝图编程事件分发器UnrealEngineUE5_哔哩哔哩_bilibili 创建一个事件分发器,这里是放在死亡事件里 比如计算场景中的敌人数量,这个UI是…...
前端面试宝典---原型链
引言----感谢大佬的讲解 大佬链接 原型链示意图 原型链问题中需要记住一句话:一切变量和函数都可以并且只能通过__proto__去找它所在原型链上的属性与方法 原型链需要注意的点 看上图可以发现 函数(构造函数)也可以通过__proto__去找到原…...
ViT 模型讲解
文章目录 一、模型的诞生背景1.1 背景1.2 ViT 的提出(2020年) 二、模型架构2.1 patch2.2 模型结构2.2.1 数据 shape 变化2.2.2 代码示例2.2.3 模型结构图 2.3 关于空间信息 三、实验3.1 主要实验3.2 消融实验 四、先验问题4.1 归纳偏置4.2 先验or大数据&…...
【技术文章的标准结构与内容指南】
技术文章的标准结构与内容指南 技术文章是传递专业知识、分享实践经验的重要媒介。一篇高质量的技术文章不仅能够帮助读者解决问题,还能促进技术交流与创新。以下是技术文章通常包含的核心内容与结构指南。 1. 标题 一个好的技术文章标题应当: 简洁明…...
Mysql概述
一、数据库相关概念 1.数据库(Data Base ,简称DB)是长期存储在计算机中有组织、可管理、可共享的数据集合。 2.数据库管理系统(Database Management System,简称为 DBMS)是管理数据库的系统软件 3.MySQL数据库全称为MySQL数据库管理系统 3.SQL语言(S…...
系统设计模块之安全架构设计(身份认证与授权(OAuth2.0、JWT、RBAC/ABAC))
一、OAuth 2.0:开放授权框架 OAuth 2.0 是一种标准化的授权协议,允许第三方应用在用户授权下访问其资源,而无需直接暴露用户密码。其核心目标是 分离身份验证与授权,提升安全性与灵活性。 1. 核心概念与流程 角色划分ÿ…...
如何管理“灰色时间”导致的成本漏洞
明确时间记录机制、优化流程透明度、应用自动化工具、强化绩效考核机制、提高员工时间意识 来有效管理。其中,明确时间记录机制 是最关键的一步。通过统一的时间记录平台,例如Toggl Track、Clockify或企业级工时系统,不仅可以实时掌握员工工作…...
程序化广告行业(84/89):4A广告代理公司与行业资质解读
程序化广告行业(84/89):4A广告代理公司与行业资质解读 大家好!在探索程序化广告行业的道路上,每一次知识的分享都是我们共同进步的阶梯。一直以来,我都希望能和大家携手前行,深入了解这个充满机…...
MTK Android12-13 -Intent Filter Verification Service 停止运行
MTK Android12-13 -Intent Filter Verification Service 停止运行 问题修复 文章目录 参考资料解决方案-修改文件源码分析源码 StatementService配置加载config_appsNotReportingCrashesActivityManagerService -retrieveSettings 加载配置AppErrors-loadAppsNotReportingCrash…...
Sentinel源码—1.使用演示和简介二
大纲 1.Sentinel流量治理框架简介 2.Sentinel源码编译及Demo演示 3.Dashboard功能介绍 4.流控规则使用演示 5.熔断规则使用演示 6.热点规则使用演示 7.授权规则使用演示 8.系统规则使用演示 9.集群流控使用演示 5.熔断规则使用演示 (1)案例说明熔断和降级 (2)Sentin…...
基于Geotools的PostGIS原始操作之CQL过滤及按属性名称生成面属性时间-以湖北省地级市行政区划为例
目录 前言 背景与意义 技术方法概述 一、CQL查询实现 1、CQL查询原理 2、Geotools中的CQL实现 二、SLD编程式样式生成 1、获取唯一的分类值 2、生成不同颜色分类 3、集成生成SLD的Style文件 三、总结 前言 随着地理信息系统(GIS)技术的快速发展…...
Linux内核中struct net_protocol的early_demux字段解析
背景问题 在内核版本4.19.0-25的头文件中,struct net_protocol结构体的定义未显式包含early_demux字段。然而,在内核版本4.19的源代码中可以看到tcp_protocol实例化时却对该字段进行了赋值: static struct net_protocol tcp_protocol = {.early_demux = tcp_v4_earl…...
TLS协议四次握手原理详解,密钥套件采用DH密钥交换算法
目录 1.TLS协议握手概述 2.TLS协议握手具体步骤 2.1.TLS第一次握手 2.2.TLS第二次握手 2.3.TLS第三次握手 2.4.TLS第四次握手 3.DH密钥交换算法 1.TLS协议握手概述 第一步客户端会发起一个消息,携带了TLS的版本号,客户端随机数,密码套…...
React 更新state中的对象
更新 state 中的对象 state 中可以保存任意类型的 JavaScript 值,包括对象。但是,你不应该直接修改存放在 React state 中的对象。相反,当你想要更新一个对象时,你需要创建一个新的对象(或者将其拷贝一份)…...
祁连山国家公园shp格式数据
地理位置:祁连山国家公园位于中国西北部,横跨甘肃省与青海省交界处,主体处于青藏高原东北边缘。总面积约5.02万平方公里,是中国首批设立的10个国家公园之一。 设立背景 试点启动:2017年,祁连山国家公园体制…...
电梯设备与电源滤波器:现代建筑中的安全守护者与电力净化师
在现代都市的钢铁森林中,电梯作为垂直交通的动脉,承载着无数人的日常出行。与此同时,在电气系统的隐秘角落,电源滤波器则默默扮演着“电力净化师”的角色,保障着各类电子设备的稳定运行。电梯设备与电源滤波器…...
Qt样式表(窗口、按钮之类,有图片和代码详细注释)
Qt样式表 1、前言2、QWdiget窗口添加背景图片2.1使用Frame解决 3、主题1(黑色背景发光边框冷色调)3.1 QWidget3.2 QPushButton3.3QLineEdit3.4 QTextEdit 4、主题二(极简冰川蓝)4.1QWidget4.2 QLineEdit4.3QTextEdit4.4QPushButto…...
在Ubuntu下进行单片机开发是否需要关闭Secure Boot
1. Secure Boot的作用 功能:Secure Boot是UEFI的安全功能,旨在阻止未经验证的驱动或操作系统启动,防止恶意软件篡改引导过程。 影响范围:它主要限制的是操作系统启动阶段加载的内核级驱动(如显卡驱动、虚拟化模块&…...