【Python网络爬虫开发】从基础到实战的完整指南
目录
- 前言:技术背景与价值
- 当前技术痛点
- 解决方案概述
- 目标读者说明
- 一、技术原理剖析
- 核心概念图解
- 核心作用讲解
- 关键技术模块
- 技术选型对比
- 二、实战演示
- 环境配置要求
- 核心代码实现(10个案例)
- 案例1:基础静态页面抓取
- 案例2:动态页面渲染(Selenium)
- 案例3:Scrapy框架应用
- 案例4:处理登录表单
- 案例5:使用代理IP
- 案例6:数据存储到CSV
- 案例7:处理分页
- 案例8:验证码处理(简单版)
- 案例9:异步爬虫
- 案例10:遵守robots.txt
- 运行结果验证
- 三、性能对比
- 测试方法论
- 量化数据对比
- 结果分析
- 四、最佳实践
- 推荐方案 ✅(10个案例)
- 常见错误 ❌(10个案例)
- 调试技巧
- 五、应用场景扩展
- 适用领域
- 创新应用方向
- 生态工具链
- 结语:总结与展望
- 技术局限性
- 未来发展趋势
- 学习资源推荐
前言:技术背景与价值
当前技术痛点
- 网页结构复杂难解析(现代网页JS动态加载占比超60%)
- 反爬机制愈发严格(验证码/IP封锁等防御手段普及率85%+)
- 海量数据处理困难(百万级数据存储效率低下)
解决方案概述
- 多协议支持:HTTP/WebSocket等协议处理
- 智能解析:XPath/CSS选择器/正则表达式组合使用
- 分布式架构:Scrapy-Redis实现横向扩展
目标读者说明
- 🕷️ 爬虫初学者:掌握基础抓取技术
- 🛠️ 中级开发者:应对反爬机制
- 📈 数据工程师:构建稳定采集系统
一、技术原理剖析
核心概念图解
核心作用讲解
网络爬虫就像智能数据采集机器人:
- 模拟浏览器:发送HTTP请求获取网页内容
- 数据提取:从HTML/JSON中抽取目标信息
- 持续运作:自动发现和跟踪新链接
- 智能对抗:绕过反爬虫检测机制
关键技术模块
模块 | 功能 | 常用工具 |
---|---|---|
请求处理 | 发送HTTP请求 | requests, aiohttp |
解析引擎 | 提取数据 | BeautifulSoup, parsel |
存储系统 | 持久化数据 | MySQL, MongoDB |
反反爬 | 绕过检测 | proxies, user-agents |
调度系统 | 任务管理 | Scrapy, Celery |
技术选型对比
场景 | requests+BS4 | Scrapy | Selenium |
---|---|---|---|
静态网页 | ✔️ 优 | ✔️ 优 | ✔️ 中 |
动态渲染 | ❌ 差 | ❌ 差 | ✔️ 优 |
并发能力 | ❌ 差 | ✔️ 优 | ❌ 差 |
学习曲线 | 低 | 中 | 高 |
二、实战演示
环境配置要求
pip install requests beautifulsoup4 scrapy selenium
核心代码实现(10个案例)
案例1:基础静态页面抓取
import requests
from bs4 import BeautifulSoupurl = "https://books.toscrape.com/"
response = requests.get(url)
soup = BeautifulSoup(response.text, 'html.parser')# 提取所有图书标题
titles = [h3.a['title'] for h3 in soup.select('h3')]
print(titles[:3]) # 输出前3个标题
案例2:动态页面渲染(Selenium)
from selenium import webdriver
from selenium.webdriver.chrome.options import Optionsoptions = Options()
options.headless = True
driver = webdriver.Chrome(options=options)driver.get("https://quotes.toscrape.com/js/")
# 等待动态内容加载
quotes = driver.find_elements_by_css_selector(".text")
print([q.text for q in quotes[:3]])
driver.quit()
案例3:Scrapy框架应用
import scrapyclass BookSpider(scrapy.Spider):name = 'book'start_urls = ['https://books.toscrape.com/']def parse(self, response):for book in response.css('article.product_pod'):yield {'title': book.css('h3 a::attr(title)').get(),'price': book.css('p.price_color::text').get()}
案例4:处理登录表单
session = requests.Session()
login_url = "https://example.com/login"
data = {'username': 'user','password': 'pass'
}
session.post(login_url, data=data)# 访问需要登录的页面
profile = session.get("https://example.com/profile")
案例5:使用代理IP
proxies = {'http': 'http://10.10.1.10:3128','https': 'http://10.10.1.10:1080'
}
response = requests.get('http://example.org', proxies=proxies)
案例6:数据存储到CSV
import csvwith open('output.csv', 'w', newline='', encoding='utf-8') as f:writer = csv.writer(f)writer.writerow(['Title', 'Price'])for item in items:writer.writerow([item['title'], item['price']])
案例7:处理分页
base_url = "https://example.com/page={}"
for page in range(1, 6):url = base_url.format(page)response = requests.get(url)# 解析数据...
案例8:验证码处理(简单版)
# 使用第三方打码平台
def handle_captcha(image_url):# 调用API识别验证码return captcha_textcaptcha_url = "https://example.com/captcha.jpg"
captcha = handle_captcha(captcha_url)
data = {'captcha': captcha}
requests.post(url, data=data)
案例9:异步爬虫
import aiohttp
import asyncioasync def fetch(session, url):async with session.get(url) as response:return await response.text()async def main():async with aiohttp.ClientSession() as session:html = await fetch(session, 'http://example.com')# 解析html...asyncio.run(main())
案例10:遵守robots.txt
from urllib.robotparser import RobotFileParserrp = RobotFileParser()
rp.set_url("https://example.com/robots.txt")
rp.read()
if rp.can_fetch("*", "https://example.com/secret-page"):# 允许抓取
else:print("禁止访问该页面")
运行结果验证
# 案例1输出:
['A Light in the Attic', 'Tipping the Velvet', 'Soumission']# 案例2输出:
['“The world as we have created it is a process of our thinking..."', ...]# 案例10输出:
禁止访问该页面
三、性能对比
测试方法论
- 测试目标:10万页面抓取任务
- 测试环境:AWS EC2 c5.xlarge
- 对比方案:同步 vs 异步 vs 分布式
量化数据对比
方案 | 耗时 | 成功率 | CPU占用 |
---|---|---|---|
同步请求 | 6h | 98% | 25% |
异步请求 | 45m | 95% | 80% |
分布式 | 12m | 99% | 95% |
结果分析
- 异步优势:速度提升8倍但成功率略降
- 分布式优势:资源利用率最大化
- 失败原因:主要来自反爬检测和网络波动
四、最佳实践
推荐方案 ✅(10个案例)
-
设置合理请求间隔
import time time.sleep(random.uniform(1,3))
-
随机User-Agent
from fake_useragent import UserAgent headers = {'User-Agent': UserAgent().random}
-
自动重试机制
from requests.adapters import HTTPAdapter session = requests.Session() session.mount('http://', HTTPAdapter(max_retries=3))
-
HTML解析容错处理
try:title = soup.select_one('h1::text').get().strip() except AttributeError:title = 'N/A'
-
使用连接池
adapter = requests.adapters.HTTPAdapter(pool_connections=100)
-
异常捕获
try:response = requests.get(url, timeout=10) except (Timeout, ConnectionError) as e:log_error(e)
-
数据去重
from hashlib import md5 url_hash = md5(url.encode()).hexdigest()
-
使用中间件
class RotateProxyMiddleware:def process_request(self, request, spider):request.meta['proxy'] = get_random_proxy()
-
分布式任务队列
from celery import Celery app = Celery('tasks', broker='redis://localhost:6379/0')
-
遵守法律规范
if not rp.can_fetch(useragent, url):raise Exception("robots.txt禁止抓取")
常见错误 ❌(10个案例)
-
忽略robots.txt
# 未经许可抓取敏感数据
-
高频访问
while True:requests.get(url) # 导致IP封禁
-
未设置超时
requests.get(url) # 默认无超时
-
硬编码XPath
'//div[2]/div[3]/span' # 结构变化即失效
-
未处理编码
text = response.content.decode() # 缺省编码可能错误
-
未验证SSL证书
requests.get(url, verify=False) # 安全风险
-
敏感信息泄露
print("正在抓取用户:" + username) # 日志记录隐私数据
-
无限递归抓取
# 未限制抓取深度导致无限循环
-
未限速
# 无延迟导致服务器压力过大
-
未去重
# 重复抓取相同URL浪费资源
调试技巧
-
使用调试代理
proxies = {"http": "http://127.0.0.1:8888"} # Charles/Fiddler
-
保存临时快照
with open("debug.html", "w") as f:f.write(response.text)
-
异常日志记录
import logging logging.basicConfig(filename='spider.log')
五、应用场景扩展
适用领域
- 电商监控:价格追踪
- 舆情分析:新闻/社交媒体采集
- SEO优化:关键词排名监测
- 学术研究:论文数据收集
创新应用方向
- AI训练数据:自动化数据集构建
- 区块链数据:链上交易记录分析
- 物联网数据:设备状态监控
生态工具链
- 框架:Scrapy, PySpider
- 浏览器自动化:Selenium, Playwright
- 验证码识别:Tesseract, 打码平台
- 代理服务:快代理, 站大爷
- 云服务:Scrapy Cloud, Crawlera
结语:总结与展望
技术局限性
- 动态渲染成本:Headless浏览器资源消耗大
- 法律风险:数据合规性要求日益严格
- AI对抗:智能验证码识别难度升级
未来发展趋势
- 智能化爬虫:结合机器学习识别页面结构
- 边缘计算:分布式节点就近采集
- 伦理规范:自动化合规性检查
学习资源推荐
- 官方文档:
- Scrapy Documentation
- Requests Documentation
- 经典书籍:《Python网络数据采集》
- 在线课程:Scrapy官方教程
相关文章:
【Python网络爬虫开发】从基础到实战的完整指南
目录 前言:技术背景与价值当前技术痛点解决方案概述目标读者说明 一、技术原理剖析核心概念图解核心作用讲解关键技术模块技术选型对比 二、实战演示环境配置要求核心代码实现(10个案例)案例1:基础静态页面抓取案例2:动…...
乐家桌面纯净版刷机ROM下载 乐家桌面纯净版2025官方最新下载
还在苦苦寻找一款好用的电视桌面,为智能电视焕新体验?别在乐家桌面纯净版刷机 ROM 下载和官方最新版下载上纠结啦,试试乐看家桌面,给你带来意想不到的惊喜! 乐家桌面纯净版或许曾吸引过你,但乐看家桌面在众…...
深度学习-全连接神经网络
四、参数初始化 神经网络的参数初始化是训练深度学习模型的关键步骤之一。初始化参数(通常是权重和偏置)会对模型的训练速度、收敛性以及最终的性能产生重要影响。下面是关于神经网络参数初始化的一些常见方法及其相关知识点。 官方文档参考࿱…...
n2n 搭建虚拟局域网,实现内网穿透
一、ubuntu linux系统上通过源码安装 1、下载源码 git clone https://github.com/ntop/n2n 2、 进入源码目录n2n,依次执行下列命令 ./autogen.sh # 如果提示命令不存在,需要运行命令:apt-get update && apt-get install autoconf…...
SystemVerilog语法之定宽数组
1.2定宽数组 1.2.1定宽数组的声明和初始化 Verilog要求在声明中必须给出数组的上下界。因为几乎所有数组都使用0作为索引下界,所以SystemVerilog允许只给出数组宽度的便捷声明方式。SystemVerilog的$clog2()函数可以计算以2为底的对数向上舍入值。你可以通过在变量…...
SQL 使用 UPDATE FROM 语法进行更新
UPDATE FROM 是一种常见的 SQL 语法模式,允许你基于其他表的数据来更新目标表。这种语法在不同数据库系统中有所不同,下面我将介绍几种主要数据库的实现方式。 PostgreSQL/SQL Server 语法 UPDATE target_table SET target_column source_table.source…...
如何在LangChain中构建并使用自定义向量数据库
1. 自定义向量数据库对接 向量数据库的发展非常迅速,几乎每隔几天就会出现新的向量数据库产品。LangChain 不可能集成所有的向量数据库,此外,一些封装好的数据库可能存在 bug 或者其他问题。这种情况下,我们需要考虑创建自定义向…...
极狐GitLab Git LFS 速率限制如何设置?
极狐GitLab 是 GitLab 在中国的发行版,关于中文参考文档和资料有: 极狐GitLab 中文文档极狐GitLab 中文论坛极狐GitLab 官网 Git LFS 速率限制 (BASIC SELF) Git LFS (Large File Storage) 是一个用于处理大文件的Git扩展。如果您在仓库中使用 Git LF…...
如何查询IP地址是否被占用?
IP地址占用查询的重要性 在当前高度发达的网络环境下,IP地址作为网络设备间通信的基础,其管理显得尤为重要。IP地址占用查询作为网络管理的一个重要环节,具有以下几点重要性: 预防IP冲突:当两个或多个设备使用相同的I…...
数字后端实现教程 | 时钟树综合IMPCCOPT-1304错误Debug思路和解决方案
今天上午有学员在做公司自己项目CTS时发现跑不下去,报了如下所示的错误IMPCCOPT-4375。 复杂时钟设计时钟树综合(clock tree synthesis)常见20个典型案例 第一次遇到这种错误,其实可以从提示信息上入手。 Term CLK_AVDD_SS is power /ground ÿ…...
AI 大模型在教育革命中的角色重塑:从知识传递者到认知伙伴
📝个人主页🌹:一ge科研小菜鸡-CSDN博客 🌹🌹期待您的关注 🌹🌹 一、引言:从“教”与“学”到“共知”时代的开启 教育的本质是什么?是教师传授知识,学生被动接受?还是引导思维、激发潜能、陪伴成长? 在过去数百年里,教育形式经历了从口述、印刷、广播到互…...
Spring如何通过XML注册Bean
在上一篇当中我们完成了对三种资源文件的读写 上篇内容:Spring是如何实现资源文件的加载 Test public void testClassPathResource() throws IOException { DefaultResourceLoader defaultResourceLoader new DefaultResourceLoader(); Resource resource …...
Compose Multiplatform Android Logcat工具
一、通过adb发送指令,收集设备日志并保存 二、UI 三、代码 /*** 获取设备列表*/fun getDevices(): List<String> {val process ProcessBuilder("adb", "devices").redirectErrorStream(true).start()val output process.inputStream.…...
智能照明系统:照亮智慧生活的多重价值
在当今科技飞速发展的时代,智能照明系统正以其独特的优势改变着人们的生活和工作方式。这套集成了物联网、人工智能等先进技术的照明解决方案,不仅实现了基本的照明功能,更在节能环保、健康舒适、安全防护等多个维度展现出卓越价值。 从能源管…...
XMC4800 芯片深度解读:架构、特性、应用与开发指南
一、芯片定位与核心优势 XMC4800是英飞凌(Infineon)推出的高性能微控制器(MCU),属于 XMC4000系列,基于 ARM Cortex-M4内核,主打 工业控制、电机驱动、物联网(IoT) 和 嵌入式系统 应用。其核心优势在于: 多核异构处理:集成Cortex-M4(144MHz,带FPU和DSP指令集)与专…...
class com.alibaba.fastjson.JSONObject cannot be cast to class
class com.alibaba.fastjson.JSONObject cannot be cast to class 在做接口测试的时候,携带一个可用的token,打算debug看看代码的执行过程,由于Redis配置类的不完整导致报错 这是原本的Redis配置类 Configuration public class RedisConfig {BeanSuppressWarnings(value {&…...
二叉树操作与遍历实现
二叉树操作与遍历实现 二叉树操作与遍历实现树的相关概念1.树的相关术语2.二叉树的概念3.二叉树的存储结构1.顺序结构2.链式结构 1. 二叉树的创建树的表示1.1 创建节点1.2 构建二叉树 2. 二叉树的销毁3. 二叉树的遍历3.1 前序遍历3.2 中序遍历3.3 后序遍历3.4 层序遍历 4. 二叉…...
VSCode连接服务器跑深度学习代码相关问题(研0大模型学习第八天)
VS Code 远程连接服务器:从环境配置到代码运行与常见问题解决实录 在使用 VS Code 通过 Remote-SSH 连接到远程服务器进行 Python 开发,特别是涉及 Anaconda 环境和深度学习项目时,可能会遇到各种各样的问题。本文记录并解答了我在配置和运行…...
软件工程中的维护类型
目录 前言1. 排错性维护1.1 排错性维护的定义与重要性1.2 排错性维护的实践与挑战 2. 适应性维护2.1 适应性维护的定义与背景2.2 适应性维护的实施策略 3. 完善性维护3.1 完善性维护的定义与目标3.2 完善性维护的实施挑战与技巧 4. 预防性维护4.1 预防性维护的定义与作用4.2 预…...
软件工程(1)
#灵感# 记录一下软件工程的相关基础知识。 按马哲的说法,不能光有实践,也需要相关理论。 定义:软件工程涉及软件开发、维护、管理等多方面的原理、方法、工具和环境。此篇主要讲软件开发中的基本方法。 已知问题:旧的软件开发主要…...
递归的模板 (以反转链表为例)
我们再来回顾一下递归的模板,终止条件,递归调用,逻辑处理。 func reverseList(head *ListNode) *ListNode {// 终止条件if head nil || head.Next nil {return head}// 逻辑处理(可能有,也可能没有,具体…...
02-HTML结构
一、URL 1.1.URL的格式 1.2.URL和URI的区别 URI指逻辑或资源的标识符,URL是地址,URL是URI的子集 二、HTML文件结构 2.1.文档声明 默认告诉浏览器是html5页面,必须放在文档最前面 <!DOCTYPE html>2.2.HTML各元素结构 是根元素&…...
C++ vector 核心功能解析与实现
目录 整体结构概述 赋值运算符重载 下标运算符重载 内存管理函数 元素访问函数 插入和删除操作 完整代码 在C标准库中, vector 是一个非常常用的动态数组容器,它能够自动管理内存,并且提供了丰富的操作接口。本文将通过分析一段手写 …...
【Linux网络】构建UDP服务器与字典翻译系统
📢博客主页:https://blog.csdn.net/2301_779549673 📢博客仓库:https://gitee.com/JohnKingW/linux_test/tree/master/lesson 📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正! &…...
DeepSeek 大模型 + LlamaIndex + MySQL 数据库 + 知识文档 实现简单 RAG 系统
DeepSeek 大模型 LlamaIndex MySQL 数据库 知识文档 实现简单 RAG 系统 以下是一个使用 DeepSeek 大模型(假设为一个高性能的中文大模型)、LlamaIndex、MySQL 数据库 和 知识文档 实现简单 RAG(检索增强生成)系统的完整示例。该…...
【FFmpeg从入门到精通】第四章-FFmpeg转码
1 FFmpeg 软编码H.264与H.265 当前网络中常见的视频编码格式要数H.264最为火热,支持H.264的封装格式有很多,如FLV、MP4、HLS(M3U8)、MKV、TS等格式;FFmpeg本身并不支持H.264的编码器,而是由FFmpeg的第三方模块对其进行支持,例如x…...
爱普生RX8130CE实时时钟成为智能家居系统的理想解决方案
智能家居的本质是让生活更便捷、舒适与智能,而精准的时间管理是实现这一目标的重要基础。爱普生 RX8130CE 实时时钟(RTC)以其卓越的性能和丰富的功能,成为智能家居系统的理想时间解决方案,为用户打造更加智能化、人性化…...
Discuz!与DeepSeek的深度融合:打造智能网址导航新标杆
引言 在数字化信息爆炸的时代,网址导航网站作为用户获取优质资源、高效浏览互联网的重要入口,其信息筛选能力、用户体验和商业化潜力成为了决定其竞争力的核心要素。Discuz!作为国内应用广泛的社区论坛系统,以其强大的功能扩展性和用户管理能…...
23种设计模式-结构型模式之代理模式(Java版本)
Java 代理模式(Proxy Pattern)详解 🧭 什么是代理模式? 代理模式是结构型设计模式之一,为其他对象提供一个代理以控制对这个对象的访问。 就像生活中的“经纪人”,你无法直接联系明星,但可以…...
网络不可达network unreachable问题解决过程
问题:访问一个环境中的路由器172.16.1.1,发现ssh无法访问,ping发现回网络不可达 C:\Windows\System32>ping 172.16.1.1 正在 Ping 172.16.1.1 具有 32 字节的数据: 来自 172.16.81.1 的回复: 无法访问目标网。 来自 172.16.81.1 的回复:…...
@RefreshScope 和@nacosvalue 的区别
文章目录 1. RefreshScope定义与作用工作原理适用场景示例代码 2. NacosValue定义与作用工作原理适用场景示例代码 3. 主要区别4. 如何选择?5. 注意事项 在 Spring 框架中, RefreshScope 和 NacosValue 是两个不同的注解,分别用于不同的场景…...
Oracle EBS R12.2 安装 -- Step by Step
一、引言 在计算机应用已经非常普及的今天,对于绝大部分个人来说,学习并掌握ORACLE ERP系统是一件“实践性”很强的事情,仅仅“纸上谈兵”而不在系统中进行具体的操作,犹如捧着一本“驾驶手册”苦读,但却没有一辆车进行上路演练,是肯定无法学会开车的道理一样,能够为自…...
【JavaEE】计算机的工作原理
计算机系统的组成 一台完整的计算机包含硬件和软件两部分,另外还有一部分固化的软件称为固件(兼具软件和硬件的特性),硬件和软件结合才能使计算机正常运行并发挥作用,所以对计算机的理解应该把它看作一个包含软件系统…...
DAY8:Oracle高可用架构深度解析与Data Guard单节点搭建实战
引言 在数据库领域,高可用性(High Availability)是保障业务连续性的核心要求。Oracle作为企业级数据库的领导者,提供了RAC、Data Guard、GoldenGate三大核心方案。本文将深入剖析这些技术的实现原理,并手把手指导搭建…...
程序的编译(预处理操作)+链接
程序的编译环境和执行环境 翻译环境:在这个环境中源代码被转换成可执行的机器指令 执行环境:用于实际执行代码 详解编译链接 翻译环境 注意: 1.组成一个程序的每个源文件通过编译过程分别转换成目标代码。 2.每个目标文件由链接器捆绑在一…...
Java 实现桌面共享-简单案例
服务器端(共享桌面) import java.awt.AWTException; import java.awt.Rectangle; import java.awt.Robot; import java.awt.Toolkit; import java.awt.image.BufferedImage; import java.io.DataOutputStream; import java.io.IOException; import java…...
Idea中实用设置和插件
目录 一、Idea使用插件 1.Fitten Code智能提示 2.MyBatisCodeHelperPro 3.HighlightBracketPair 4.Rainbow Brackets Lite 5.GitToolBox(存在付费) 6.MavenHelperPro 7.Search In Repository 8.VisualGC(存在付费) 9.vo2dto 10.Key Promoter X 11.CodeGlance…...
获取电脑信息(登录电脑的进程、C盘文件信息、浏览器信息、IP)
电脑的进程信息 // 获取登录电脑的进程信息String os System.getProperty("os.name").toLowerCase();String command;if (os.contains("win")) {command "tasklist";} else {command "ps -ef";}try {Process process new ProcessB…...
单例模式(线程安全)
1.什么是单例模式 单例模式(Singleton Pattern)是一种创建型设计模式,旨在确保一个类只有一个实例,并提供一个全局访问点来访问该实例。这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单…...
Sentinel源码—7.参数限流和注解的实现二
大纲 1.参数限流的原理和源码 2.SentinelResource注解的使用和实现 2.SentinelResource注解的使用和实现 (1)SentinelResource注解的使用 (2)SentinelResource注解和实现 (1)SentinelResource注解的使用 一.引入Sentinel Spring Boot Starter依赖 <dependency><…...
【单片机 C语言】单片机学习过程中常见C库函数(学习笔记)
memset() C 标准库 - <string.h> string .h 头文件定义了一个变量类型、一个宏和各种操作字符数组的函数。 <string.h> 是 C 标准库中的一个头文件,提供了一组用于处理字符串和内存块的函数。这些函数涵盖了字符串复制、连接、比较、搜索和内存操作…...
聚类算法(K-means、DBSCAN)
聚类算法 K-means 算法 算法原理 K-means 是一种基于类内距离最小化的划分式聚类算法,其核心思想是通过迭代优化将数据划分为 K 个簇。目标函数为最小化平方误差(SSE): S S E ∑ i 1 K ∑ x ∈ C i ∣ ∣ x − μ i ∣ ∣ 2…...
Spring AI Alibaba Graph基于 ReAct Agent 的天气预报查询系统
1、在本示例中,我们仅为 Agent 绑定了一个天气查询服务,接收到用户的天气查询服务后,流程会在 AgentNode 和 ToolNode 之间循环执行,直到完成用户指令。示例中判断指令完成的条件(即 ReAct 结束条件)也很简…...
C++初阶——模板
C初阶——模板 一、概念引入 1.如何实现一个通用的交换函数,使它既可以用来交换各种类型的数据呢? 通过前面的学习,我们知道函数重载可以帮我们实现这一功能,代码如下: 运行结果如图: 使用函数重载虽然…...
【技术派后端篇】技术派中基于 Redis 的缓存实践
在互联网应用追求高并发和高可用的背景下,缓存对于提升程序性能至关重要。相较于本地缓存 Guava Cache 和 Caffeine,Redis 具有显著优势。Redis 支持集群和分布式部署,能横向扩展缓存容量和负载能力,适应大型分布式系统的缓存需求…...
系统安装及应用
重点 账号安全控制 系统引导和登陆控制 弱口令检测 端口扫描 前言 随着信息技术的快速发展,系统安全成为我们日常生活和工作中不可或缺的一部分。本章节主要探讨系统安全及应用,涵盖了账号安全控制、系统引导和登录控制、弱口令检测以及端口扫描等多个方面,为我们提供了一…...
发布事件和Insert数据库先后顺序
代码解释 csharp await PublishCreatedAsync(entity).ConfigureAwait(false); await Repository.InsertAsync(entity).ConfigureAwait(false);PublishCreatedAsync(entity):这是一个异步方法,其功能是发布与实体创建相关的事件。此方法或许会通知其他组…...
【英语语法】词法---冠词
目录 冠词一、不定冠词:a / an1. 基本用法2. 主要使用场景3. 特殊情况 二、定冠词:the1. 基本用法2. 主要使用场景3. 特殊情况 三、零冠词1. 基本规则2. 特殊情况 四、冠词对比五、常见错误总结 冠词 冠词是英语中用于限定名词的一类虚词,分…...
android的 framework 有哪些知识点和应用场景
Android Framework 知识点 1. 四大组件 Activity(活动) 是 Android 应用中最基本的组件,用于实现用户界面。一个 Activity 通常对应一个屏幕的内容。有自己的生命周期,包括 onCreate、onStart、onResume、onPause、onStop、onDe…...
Prompt 攻击与防范:大语言模型安全的新挑战
随着大语言模型(LLM)在企业服务、智能助手、搜索增强等领域的广泛应用,围绕其"Prompt"机制的安全问题也逐渐引起关注。其中最具代表性的,就是所谓的 Prompt Injection(提示词注入)攻击。 本文将…...