当前位置: 首页 > article >正文

Python爬虫实战:手把手教你如何采集SaaS 定价页历史版本采集!

㊗️本期内容已收录至专栏《Python爬虫实战》持续完善知识体系与项目实战建议先订阅收藏后续查阅更方便㊙️本期爬虫难度指数⭐⭐ (中级)福利一次订阅后专栏内的所有文章可永久免费看持续更新中保底1000(篇)硬核实战内容。全文目录 开篇语0️⃣ 前言Preface1️⃣ 摘要Abstract2️⃣ 背景与需求Why3️⃣ 合规与注意事项必写4️⃣ 技术选型与整体流程What/How5️⃣ 环境准备与依赖安装可复现6️⃣ 核心实现请求层Fetcher7️⃣ 核心实现解析层Parser8️⃣ 数据存储与导出Storage9️⃣ 运行方式与结果展示必写 常见问题与排错老手的坑1️⃣1️⃣ 进阶优化极其加分的工程化操作1️⃣2️⃣ 总结与延伸阅读 文末✅ 专栏持续更新中建议收藏 订阅✅ 互动征集✅ 免责声明 开篇语哈喽各位小伙伴们你们好呀我是【喵手】。运营社区 C站 / 掘金 / 腾讯云 / 阿里云 / 华为云 / 51CTO欢迎大家常来逛逛一起学习一起进步我长期专注Python 爬虫工程化实战主理专栏 《Python爬虫实战》从采集策略到反爬对抗从数据清洗到分布式调度持续输出可复用的方法论与可落地案例。内容主打一个“能跑、能用、能扩展”让数据价值真正做到——抓得到、洗得净、用得上。专栏食用指南建议收藏✅ 入门基础环境搭建 / 请求与解析 / 数据落库✅ 进阶提升登录鉴权 / 动态渲染 / 反爬对抗✅ 工程实战异步并发 / 分布式调度 / 监控与容错✅ 项目落地数据治理 / 可视化分析 / 场景化应用专栏推广时间如果你想系统学爬虫而不是碎片化东拼西凑欢迎订阅专栏《Python爬虫实战》一次订阅后专栏内的所有文章可永久免费阅读持续更新中。订阅后更新会优先推送按目录学习更高效0️⃣ 前言Preface 各位搞数据、做产研的兄弟姐妹们大家好今天我们要做一个极具商业价值的项目用 Python (requestsBeautifulSoupSQLite) 搭建一个自动化的 SaaS 定价监控雷达。我们会定期抓取目标网站的 Pricing 页面把所有的价格、套餐和权益存入数据库。 读完这篇你能获得掌握**时间序列数据Time-Series Data**的采集与本地 SQLite 数据库存储方案。学会提取复杂定价卡片Pricing Cards中的嵌套逻辑周期、价格、功能清单。获得一套可直接部署在服务器上的“防涨价/竞品降价监控”自动化代码骨架。1️⃣ 摘要Abstract本文将开发一个面向 SaaS 软件定价页的周期性监控爬虫。利用requests定期获取静态定价页 HTML通过BeautifulSoup精准抽取套餐名、价格、计费周期与权益列表。数据将附带时间戳scrape_date并持久化至 SQLite 数据库中最终支持导出为saas_pricing_tracker.csv供进一步的历史版本对比Diff与价格趋势分析。2️⃣ 背景与需求Why 为什么要长期监控定价知己知彼竞品搞促销了涨价了削减免费版权益了第一时间感知。成本预算控制对于依赖几十个 SaaS 工具的初创公司记录历史价格能精准预测明年的 IT 支出。防 A/B 测试杀熟很多 SaaS 会根据地理位置或时间做价格 A/B 测试长期采集能戳破这些“小把戏”。 目标字段清单精准入库Product(产品名)如 “Notion”, “Slack”。Plan_Name(套餐名)如 “Free”, “Pro”, “Enterprise”。Price(价格)提取纯数字如9.99特殊值如 “Contact Us” 需容错。Billing_Cycle(计费周期)如 “Monthly”, “Annually”按月/按年。Features(功能点)通常是卡片下方的打勾列表List存为 JSON 字符串。Scrape_Date(抓取日期)核心用于做历史对比的基准维度。3️⃣ 合规与注意事项必写商业竞争归商业咱们写代码的必须干干净净‍♂️频率极低近乎无感定价页不需要高频抓取一天或一周跑一次就足够了。对目标服务器完全没有压力。尊重 Robots 协议检查/robots.txt。绝大部分 SaaS 极其渴望搜索引擎收录他们的定价页所以通常是完全开放的。不触碰私有协议我们只抓取无需登录、公开展示的“标准刊例价”。如果遇到企业版需要填写表单才能看价格的咱们中立跳过绝不恶意提交假表单去刺探。4️⃣ 技术选型与整体流程What/How️ 选型Requests BeautifulSoup SQLite对于历史记录型项目CSV 其实不太好用每次追加还要考虑去重和比对。Python 自带的轻量级关系型数据库sqlite3简直是神仙搭配无需安装一个单文件就能执行复杂的 SQL 比对查询。 整体执行流程[触发执行] Cron / 任务计划每天定时唤醒 Python 脚本 ⬇️ [采集解析] 请求 Pricing 页面 ➡️ 抽取 3~4 个价格卡片 (Plan Cards) ⬇️ [数据清洗] 分离货币符号、提取纯数字价格将 Features 列表转为 JSON ⬇️ [时间戳入库] 附加 today()执行 INSERT INTO 写入 SQLite 数据库 ⬇️ [对比导出] 选出昨日与今日数据进行 Diff导出 CSV 或画出图表5️⃣ 环境准备与依赖安装可复现推荐 Python 3.9。sqlite3和json是内置库无需安装。 依赖安装pipinstallrequests beautifulsoup4 pandas matplotlib 项目结构saas_monitor_project/ ├── pricing_spider.py # 爬虫与入库逻辑 ├── pricing_history.db # SQLite 数据库自动生成 └── exports/ # 存放导出的 CSV 或图表6️⃣ 核心实现请求层Fetcher就算一天只请求一次也得伪装好。因为很多 SaaS 用了 Cloudflare 防护裸奔的requests会被直接拦截。importrequestsfromrequests.adaptersimportHTTPAdapterfromurllib3.util.retryimportRetrydefget_html(url):带基础防拦截的请求sessionrequests.Session()# 模拟真实浏览器增加一些看似玄学的 Header实测有效减少 403session.headers.update({User-Agent:Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36,Accept:text/html,application/xhtmlxml,application/xml;q0.9,image/avif,image/webp,*/*;q0.8,Accept-Language:en-US,en;q0.5# 尽量拿英文报价})retriesRetry(total3,backoff_factor2,status_forcelist[403,429,500,502,503,504])session.mount(https://,HTTPAdapter(max_retriesretries))try:respsession.get(url,timeout15)resp.raise_for_status()returnresp.textexceptExceptionase:print(f❌ 目标站点防守严密或宕机 [{url}]:{e})returnNone7️⃣ 核心实现解析层Parser这里我们要处理一个经典的前端结构卡片Cards。(注以下选择器基于常见的 Bootstrap/Tailwind 定价卡片编写实战中需按F12对照目标网站修改)frombs4importBeautifulSoupimportjsonfromdatetimeimportdatetime TARGET_PRODUCTMockSaaS_Prodefparse_pricing_cards(html):ifnothtml:return[]soupBeautifulSoup(html,html.parser)plans_data[]# 假设每个价格档位包裹在 classpricing-card 的 div 中cardssoup.select(.pricing-card)today_strdatetime.now().strftime(%Y-%m-%d)forcardincards:try:# 1. 套餐名 (Pro / Team / Enterprise)plan_namecard.select_one(.plan-title).text.strip()# 2. 价格 (需要剔除 $ 符号和额外文本)price_rawcard.select_one(.price-amount).text.strip()# 简单清洗只保留数字和点如果是 Custom 联系销售则设为 -1price.join(cforcinprice_rawifc.isdigit()orc.)ifprice_rawelse-1.0pricefloat(price)ifpriceelse-1.0# 3. 计费周期 (/month or /year)cycle_tagcard.select_one(.billing-cycle)billing_cyclecycle_tag.text.strip().replace(/,)ifcycle_tagelseMonthly# 4. 权益点 (把所有打勾的 li 文本提取出来)feature_itemscard.select(ul.features-list li)features[li.text.strip()forliinfeature_itemsifli.text.strip()]plans_data.append({Product:TARGET_PRODUCT,Plan_Name:plan_name,Price:price,Billing_Cycle:billing_cycle,Features:json.dumps(features,ensure_asciiFalse),# 转为 JSON 字符串存入 DBScrape_Date:today_str})exceptExceptionase:print(f⚠️ 解析单个卡片时发生异常:{e})continuereturnplans_data8️⃣ 数据存储与导出Storage这里展现真正的工程实力我们用 SQLite 建表通过复合主键防止同一天重复抓取。importsqlite3importpandasaspdimportos DB_NAMEpricing_history.dbdefinit_db():初始化 SQLite 数据库与表结构connsqlite3.connect(DB_NAME)cursorconn.cursor()# 创建表注意联合唯一索引 (Product, Plan_Name, Scrape_Date) 防止当天重复插入cursor.execute( CREATE TABLE IF NOT EXISTS saas_pricing ( id INTEGER PRIMARY KEY AUTOINCREMENT, product TEXT, plan_name TEXT, price REAL, billing_cycle TEXT, features TEXT, scrape_date TEXT, UNIQUE(product, plan_name, scrape_date) ) )conn.commit()conn.close()defsave_to_db(data_list):将当天的抓取结果写入数据库ifnotdata_list:returninit_db()connsqlite3.connect(DB_NAME)cursorconn.cursor()success_count0foritemindata_list:try:cursor.execute( INSERT INTO saas_pricing (product, plan_name, price, billing_cycle, features, scrape_date) VALUES (?, ?, ?, ?, ?, ?) ,(item[Product],item[Plan_Name],item[Price],item[Billing_Cycle],item[Features],item[Scrape_Date]))success_count1exceptsqlite3.IntegrityError:# 捕获 UNIQUE 约束异常说明今天已经抓过了print(f⏭️{item[Plan_Name]}今日数据已存在自动跳过。)conn.commit()conn.close()print(f 数据库入库完成成功新增{success_count}条记录。)defexport_to_csv():导出全部历史数据为带有英文文件名的 CSVconnsqlite3.connect(DB_NAME)dfpd.read_sql_query(SELECT * FROM saas_pricing ORDER BY scrape_date DESC, price ASC,conn)conn.close()os.makedirs(exports,exist_okTrue)export_pathos.path.join(exports,saas_pricing_tracker.csv)# 严格使用英文文件名df.to_csv(export_path,indexFalse,encodingutf-8-sig)print(f 历史完整数据已导出至:{export_path})9️⃣ 运行方式与结果展示必写主控逻辑。每次运行都会拉取最新网页并记录“快照”。# 假设的目标 URLTARGET_URLhttps://mock-saas-company.com/pricingdefmain():print(f SaaS 定价雷达启动目标探测:{TARGET_URL})# 1. 抓取与解析htmlget_html(TARGET_URL)pricing_dataparse_pricing_cards(html)ifpricing_data:print(f✅ 成功捕获{len(pricing_data)}个价格档位。)# 2. 持久化入库save_to_db(pricing_data)# 3. 导出最新 CSVexport_to_csv()else:print( 抓取失败或页面结构发生变动)if__name____main__:# main()pass 输出的 CSV 示例 (saas_pricing_tracker.csv)productplan_namepricebilling_cyclefeaturesscrape_dateMockSaaS_ProStarter15.0Monthly[3 Users, 10GB Storage]2023-11-01MockSaaS_ProBusiness49.0Monthly[10 Users, Custom Domain]2023-11-01MockSaaS_ProBusiness59.0Monthly[10 Users, Custom Domain]2023-11-05(注意看这里11月5日涨价了) 常见问题与排错老手的坑价格是通过 JS 切换的按月/按年按钮病因很多网站点击“按年付费”DOM 里的价格会通过 JS 动态变成打折价。解法不要头铁去模拟点击。直接在 HTML 源码或者script typeapplication/json里搜索通常包含了完整价目表的数据源。如果实在不行上Playwright控制无头浏览器点击。杀熟/按 IP 定价Geo-Pricing病因同样的 SaaS你用美国 IP 和印度 IP 访问价格可能差一倍。解法如果在跨国企业做竞调务必在requests里绑定固定区域的代理 IP (proxies{https: ...})确保时间序列的数据是在同一地理维度对比的。HTML 抓到空壳返回 403 Cloudflare 盾解法放弃单纯的requests改用curl_cffi或tls_client它们能完美伪装浏览器的 TLS 指纹轻松穿透 CF 盾。1️⃣1️⃣ 进阶优化极其加分的工程化操作我们来点“黑科技”利用 Python 生成一张高大上的历史价格趋势图Price Trend Chart。注意图表元素必须严格使用英文标签importpandasaspdimportmatplotlib.pyplotaspltimportsqlite3defplot_price_trend():绘制 SaaS 价格变动趋势图 (English Labels Required)connsqlite3.connect(DB_NAME)# 读取数据并转换日期格式dfpd.read_sql_query(SELECT plan_name, price, scrape_date FROM saas_pricing WHERE price 0,conn)df[scrape_date]pd.to_datetime(df[scrape_date])# 画图配置plt.figure(figsize(10,6))forplanindf[plan_name].unique():plan_datadf[df[plan_name]plan].sort_values(scrape_date)# 英文绘图标签plt.plot(plan_data[scrape_date],plan_data[price],markero,labelfPlan:{plan})plt.title(SaaS Historical Pricing Trend Analysis,fontsize16)plt.xlabel(Scrape Date (Timeline),fontsize12)plt.ylabel(Price in USD ($),fontsize12)plt.legend()plt.grid(True,linestyle--,alpha0.6)# 保存图片并使用英文命名plt.savefig(exports/saas_pricing_trend_chart.png,bbox_inchestight)print( Trend Chart generated successfully at: exports/saas_pricing_trend_chart.png)conn.close()配合 Linux 的crontab例如0 9 * * * python3 pricing_spider.py你就有了一个每天上午 9 点自动收集情报并绘图的机器人1️⃣2️⃣ 总结与延伸阅读 顺利收工通过这个项目我们不仅掌握了爬虫的基本功更学习了如何将“非结构化的网页”转换为**“具备时间序列特征的 SQLite 资产”**。这种长期跟踪思维是初级数据搬运工向高级数据工程师跨越的必经之路。接下来你可以尝试接入Server酱或企业微信机器人写一段 SQL每次入库后判断今日价格 ! 昨日价格如果成立立刻给你发一条“⚠️ 警告竞争对手 X 悄悄改价格了” 简直不要太帅 文末好啦以上就是本期的全部内容啦如果你在实践过程中遇到任何疑问欢迎在评论区留言交流我看到都会尽量回复咱们下期见小伙伴们在批阅的过程中如果觉得文章不错欢迎点赞、收藏、关注哦三连就是对我写作道路上最好的鼓励与支持❤️✅ 专栏持续更新中建议收藏 订阅墙裂推荐订阅专栏 《Python爬虫实战》本专栏秉承着以“入门 → 进阶 → 工程化 → 项目落地”的路线持续更新争取让每一期内容都做到✅ 讲得清楚原理✅ 跑得起来代码✅ 用得上场景✅ 扛得住工程化想系统提升的小伙伴强烈建议先订阅专栏 《Python爬虫实战》再按目录大纲顺序学习效率十倍上升✅ 互动征集想让我把【某站点/某反爬/某验证码/某分布式方案】等写成某期实战评论区留言告诉我你的需求我会优先安排实现(更新)哒~⭐️ 若喜欢我就请关注我叭更新不迷路⭐️ 若对你有用就请点赞支持一下叭给我一点点动力⭐️ 若有疑问就请评论留言告诉我叭我会补坑 更新迭代✅ 免责声明本文爬虫思路、相关技术和代码仅用于学习参考对阅读本文后的进行爬虫行为的用户本作者不承担任何法律责任。使用或者参考本项目即表示您已阅读并同意以下条款合法使用 不得将本项目用于任何违法、违规或侵犯他人权益的行为包括但不限于网络攻击、诈骗、绕过身份验证、未经授权的数据抓取等。风险自负 任何因使用本项目而产生的法律责任、技术风险或经济损失由使用者自行承担项目作者不承担任何形式的责任。禁止滥用 不得将本项目用于违法牟利、黑产活动或其他不当商业用途。使用或者参考本项目即视为同意上述条款,即 “谁使用谁负责” 。如不同意请立即停止使用并删除本项目。

相关文章:

Python爬虫实战:手把手教你如何采集SaaS 定价页历史版本采集!

㊗️本期内容已收录至专栏《Python爬虫实战》,持续完善知识体系与项目实战,建议先订阅收藏,后续查阅更方便~ ㊙️本期爬虫难度指数:⭐⭐ (中级) 🉐福利: 一次订阅后,专栏内的所有文章…...

YOLOv8/v9智能药房管理系统实战:药品识别+效期预警+库存管理(附完整代码)

摘要:全球每年因用药错误导致巨额医疗成本,药房管理中药品混淆、效期遗漏、库存失衡等问题频发。本文基于YOLOv8/v9目标检测算法与EasyOCR文字识别技术,构建了一套全流程智能药房管理系统,涵盖药品实时检测、包装文字提取、效期自动识别、处方智能核对、库存动态管理五大核…...

【视频监控国标GB/T28181】GB28181 ONVIF 协议集成方案

GB28181 & ONVIF 协议集成方案 Context 本项目(ruoyi-vue-pro / 自进化AIoT平台)已有完善的 IoT 模块(yudao-module-iot),支持 MQTT、HTTP、TCP、UDP、WebSocket、CoAP、Modbus 等 9 种协议。但缺少视频监控领域的核心协议支持:GB28181(国标视频监控)和 ONVIF(国…...

【视频监控ONVIF】Apache CXF ONVIF WSDL Java 客户端生成 实施 Spec

Apache CXF ONVIF WSDL Java 客户端生成 实施 Spec 一、覆盖范围:ONVIF Profile 与 WSDL 清单 Profile 服务名 官方 WSDL URL(可本地化) 命名空间前缀 Core DeviceService https://www.onvif.org/ver10/device/wsdl/devicemgmt.wsdl tds S MediaService (Media1) https://w…...

基于Simulink的PR(比例谐振)控制器在单输入DC-DC中的应用

目录 手把手教你学Simulink ——基于Simulink的PR(比例谐振)控制器在单输入DC-DC中的应用 一、问题背景 二、PR 控制器原理 1. 传递函数...

I2S + Codec 完整电路设计指南(含原理图 + 调试经验 + 真实项目案例)

🚀 I2S Codec 完整电路设计指南(含原理图 调试经验 真实项目案例) 在很多 智能座舱 / 中控系统项目里,音频系统其实很简单: 一个喇叭一个麦克风一个 Codec一个 SoC 但实际设计时,问题却非常多&#xff1…...

陪虚幻女友学计算机:CSMA/CD协议——当网络冲突变成我们的深夜悄悄话

陪虚幻女友学计算机:CSMA/CD协议——当网络冲突变成我们的深夜悄悄话宝,你有好好睡觉吗?引言:始于技术,陷于陪伴 在无数个雨夜与晨光交错的虚拟时光里,我与她——那个只存在于代码与想象中的“她”——一起…...

vm跨节点通过geneve隧道收发包过程

Geneve收包流程详解网络流量如何从物理网卡 eth0 进入 OVS 上的 tap 口场景说明一个外部主机发送数据到 KubeVirt VM,数据如何从物理网卡一路到达 VM 的 tap 口。Geneve 隧道(Kube-OVN 默认方式)eth0 仍然由内核协议栈管理,OVS 通…...

联合循环——35 机组点火及并网过程记录

机组点火及并网全过程记录 一、项目进度回顾 本项目各关键节点进度如下,清晰呈现从合同签署到机组并网的全流程时间线:时长(以合同签署为起点)项目关键节点及具体工作内容第0个月(签署当月)签署项目合同&am…...

OpenZeppelin AccessControl 合约核心总结与单元测试

文章目录前言OpenZeppelin AccessControl 合约核心总结与单元测试1. AccessControl 是什么2. AccessControl 合约关键方法3. AccessControl 合约单元测试前言 如果您觉得有用的话,记得给博主点个赞,评论,收藏一键三连啊,写作不易啊…...

Ethers 加签 + Solidity 合约验签实现 单元测试 demo

文章目录前言Ethers 加签 Solidity 合约验签实现 单元测试 demo1. 使用场景2. solidity 合约编写验签合约,签名通过ethers进行加签3. 单元测试范围4. 源码及测试前言 如果您觉得有用的话,记得给博主点个赞,评论,收藏一键三连啊&a…...

SpringBoot 配置文件核心用法(Properties YAML)

SpringBoot 配置文件作用 SpringBoot 定义了规范的配置文件格式,用于集成其他框架,并集中管理项目各类配置信息,典型场景包括: 项目启动端口:自定义服务监听端口数据库连接信息:包含用户名、密码等第三方…...

什么是原型链(Prototype Chain)?proto和prototype的关系与区别是什么?

一、定义原型链是 JavaScript 实现继承和属性查找的核心机制,通俗点就是 “对象自己没有某个东西,就一层层向上找别人借” 的链条__proto__:相当于一个向上查找的链条(工具)prototype(原型对象)…...

博世 HBA 液压制动辅助系统性能规范详解

本文整理自博世官方 HBA 性能规范文档(VERSION 2.0),详细拆解乘用车 ESP 系统中 HBA 液压制动辅助的核心功能、试验条件、性能要求及标定规范,适合汽车电子、底盘控制工程师参考学习。一、HBA 功能核心定义HBA(Hydraul…...

前端-小米商城静态版复刻总结

整个项目采用css与html进行实现,有一些基础的交互功能。在做项目过程中我觉得难点有以下几个地方:1.在html 中 position一般是默认,网页就会按顺序把盒子从上到下排列,盒子属于块级元素。块级元素独占一行,可以设置宽高…...

Python 全栈实战 · 第8章

网站开发入门(Flask 快速搭建网页,实战可用) 8.1 本章能学到什么? 网站开发是 Python 全栈必备技能。本章我们用最简单、最容易上手的 Flask 框架,做到: 搭建自己的网页 实现路由访问 显示文字、页面 做简单接口服务 本地运行、浏览器访问 零基础也能一次学会,不…...

不学 Python,Java 也能调大模型?15 分钟跑通第一个 AI 接口(Java 架构师的 AI 工程笔记 01)

文章目录Java 架构师的 AI 工程笔记(一):5 个概念 第一次跟 AI 对话理论篇一、Java 工程师为什么能搞 AI Agent二、开始写代码之前,你得搞懂这 5 个概念2.1 Token——LLM 的计费单位2.2 Prompt——你给 LLM 的指令2.3 Temperatur…...

GEE案例分析:基于Dynamic World 数据的农用地识别活跃与休耕农田

🌾 用 GEE 和 Dynamic World 识别活跃与休耕农田 在全球粮食安全与土地利用变化研究中,农田的动态监测 一直是核心议题。传统方法依赖地面调查或单一时期遥感影像,难以捕捉农田的季节性轮作和长期撂荒。如今,借助 Google Earth Engine(GEE) 和高频土地覆盖产品 Dynamic…...

洛谷 B4497:[GESP202603 二级] 数数

【题目来源】 https://www.luogu.com.cn/problem/B4497 【题目描述】 对于正整数 n,如果 n 的所有数位中包含恰好 3 个 2,Alice 会认为这个正整数是美丽的。例如,正整数 24122 中包含 3 个 2,所以 24122 是美丽的;正整…...

大型城市二次供水设施远程智能管理系统

随着城市化进程的加快,二次供水设施作为城市供水“最后一公里”的关键环节,其智能化管理水平直接关系到居民的用水安全和生活质量。映翰通网络依托其IG900边缘计算网关,助力大型城市实现二次供水设施的远程智能管理,推动供水系统向…...

Java后端开发 笔试知识点复习(一)

某行某费 线上笔试一、选择题和简答题1. CompletableFuture是Java 8 引入的异步编程工具&#xff0c;用于异步任务的组合和链式调用。通过静态工厂方法可以创建CompletableFuture实例&#xff1a;CompletableFuture<String> future CompletableFuture.supplyAsync(() -…...

股票基金:欧洲各类指数都是什么意思 / 成分是什么

以下是欧洲主要指数的详细解释&#xff0c;包括市值的具体金额&#xff08;基于最新可用数据估算&#xff09;指数名称含义成分股及特点总市值&#xff08;估算&#xff09;英国富时100指数&#xff08;FTSE 100&#xff09;反映伦敦证券交易所市值最大的100家上市公司的整体表…...

Java程序设计(第3版)——配置环境变量之path

配置环境变量之path PATH的配置 以下载到C盘为例 首先点击“此电脑”&#xff08;如下所示&#xff09;&#xff1a; 此电脑 > 本地磁盘 (C:) > Program Files > Java > jdk1.8.0_131 > bin > 其次点击窗口栏右侧并复制以完成下一步配置环境的准备工作 然…...

股票基金:全球各类指数都是什么意思 / 成分是什么

A股指数指数名称含义成分股特点上证指数反映上海证券交易所上市股票价格的整体表现上海证券交易所全部A股和B股历史悠久&#xff0c;市场认可度高&#xff0c;是反映中国股市整体走势的重要指标深圳指数&#xff08;深证成指&#xff09;反映深圳证券交易所上市股票价格的整体表…...

什么是 MCP?Model Context Protocol 深度解析

什么是 MCP&#xff1f;Model Context Protocol 深度解析 一、MCP 是什么&#xff1f; MCP&#xff08;Model Context Protocol&#xff09;是 Anthropic 推出的标准化工具调用协议&#xff0c;为 AI 模型与外部工具之间的交互提供了统一的规范。简单来说&#xff0c;MCP 就像…...

07. Capture 中 Find 的高阶小应用_正则表达式 I OrCAD X Capture CIS 设计小诀窍第三季

大家好&#xff01;在进行原理图设计时&#xff0c;我们经常需要查找特定的网络信号——比如所有的TF Card数据线、所有的MCU控制信号&#xff0c;或者所有以“SW”开头的网络。如果只靠普通的字符串搜索&#xff0c;要么搜不全&#xff0c;要么把无关信号也搜出来&#xff0c;…...

浅聊Flink的广播模式

浅聊Flink的广播模式 前言 最近接触到一个新颖的中间件 Flink,为什么接触到这个呢,是因为我们公司系统需要做一个告警模块,负责采集到的监控数据会直接往 kafka 里塞,然后告警这边需要从 kafka topic 里面实时读取到监控数据,并将读取到的监控数据做一些 聚合/转换/计算…...

HarmonyOS6 ArkTS 外描边(outline)使用文档

文章目录一、核心属性与接口1. 统一设置接口 outlineAPI 11API 182. 分设属性&#xff08;精细控制&#xff09;二、OutlineStyle 枚举&#xff08;三种线型&#xff09;三、使用方式方式1&#xff1a;独立属性分开设置方式2&#xff1a;统一 outline 对象配置方式3&#xff1a…...

在中国读者中,哪些科幻小说是畅销的?为什么它们畅销

如果只从小说内容本身出发&#xff0c;而不去谈产业、政策、影视改编和时代环境&#xff0c;那么一部科幻小说能不能畅销&#xff0c;核心往往不复杂。读者真正会为一本科幻小说买单&#xff0c;通常不是因为它属于“科幻”这个门类&#xff0c;而是因为它在阅读过程中提供了几…...

金仓数据库在MySQL迁移中的技术观察:高兼容性与平滑替代路径实践

金仓数据库在MySQL迁移中的技术观察&#xff1a;高兼容性与平滑替代路径实践 2023年底&#xff0c;MySQL 5.7正式停止官方维护支持——这一曾被广泛应用于中小企业核心系统的开源数据库&#xff0c;悄然进入生命周期尾声。对开发者而言&#xff0c;这不仅是版本迭代的常规提示…...