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

Jenkins 学习总结滩

先唠两句参数就像餐厅点单把API想象成一家餐厅的“后厨系统”。? 路径参数/dishes/{dish_id} - 好比你要点“宫保鸡丁”这道具体的菜它是菜单资源路径的一部分。查询参数/dishes?spicytruetypeSichuan - 好比你说“我要川菜要辣的”。这是对结果的筛选和描述不是特定资源。请求体 - 你递进去的详细订单包括要什么菜、口味、备注内容可以很复杂。Cookie / Header - 像是你的会员卡自动带身份或者你给服务员的口头特殊要求如“快点上”。搞清楚这个参数该放哪儿基本就对了一半。另一半在于怎么让后厨你的代码准确无误地理解这些“订单”。第一部分基础必知——路径与查询参数好咱们先来聊聊最常用的两个兄弟。路径参数锁定具体目标用来唯一标识一个资源。想象一下你要获取ID为42的用户信息路径就是 /users/42。from fastapi import FastAPIapp FastAPI()app.get(/items/{item_id})async def read_item(item_id: int): # FastAPI自动将路径中的item_id转换为intreturn {item_id: item_id}关键点参数类型声明如int至关重要FastAPI会据此自动进行类型转换和验证。如果你传个“abc”进来它会礼貌地返回一个错误而不是让你的代码崩溃。这里千万别学我当初偷懒所有参数都定义成字符串到函数内部再转换。结果就是错误处理代码散落一地调试起来想哭。查询参数提供筛选与选项它不是路径的一部分跟在?后面用连接。比如 /items/?skip0limit10。app.get(/items/)async def read_items(skip: int 0, limit: int 10):return {skip: skip, limit: limit}注意到 0和 10了吗这给了它们默认值让它们变成了可选参数。没有默认值的参数就是必选查询参数。官方文档虽然把查询参数讲得很简单但根据我们的线上经验对于复杂的分页过滤接口强烈建议用Pydantic模型来封装查询参数而不是把一长串参数都列在函数定义里维护起来简直是灾难。这个我们后面讲。? 第二部分进阶必备——参数验证与请求体接下来重点来了如何确保客人点的菜是合理的比如“宫保鸡丁”要求加“草莓”这得拦住。用Query、Path、Body等工具精细控制Fastapi提供了这些“工具函数”让你能对参数进行更多描述。from fastapi import Query, Pathapp.get(/items/{item_id})async def read_items(item_id: int Path(..., title商品ID, ge1), # ...表示无默认值必填。ge1表示大于等于1q: str Query(None, min_length3, max_length50), # 可选参数None是默认值size: float Query(1.0, gt0, lt10) # 可选必须大于0小于10):return {item_id: item_id, q: q, size: size}踩坑提醒当同一个参数既可能是路径参数又可能是查询参数时虽然设计上应避免FastAPI默认会认为是查询参数。你必须显式使用Path来声明它是路径参数。请求体Body处理复杂数据当数据复杂时比如创建一篇博客文章就用请求体通常是POST/PUT。核心工具Pydantic模型。这简直是FastAPI的“王牌搭档”数据验证和序列化的神器。from pydantic import BaseModelclass Item(BaseModel):name: strdescription: str | None Noneprice: floattax: float | None Noneapp.post(/items/)async def create_item(item: Item): # FastAPI会自动从请求体中识别itemreturn item你可能会问多个参数混着来怎么办比如路径参数、查询参数和请求体模型一起放心FastAPI智能到令人发指。它会自动识别1 参数在路径中或Path()声明 - 路径参数2 单数类型int, str等且有/无默认值(必填/非必填)或Query()声明等不在路径中 - 查询参数3 Pydantic模型类型 - 请求体app.put(/items/{item_id})async def update_item(item_id: int, # 路径参数q: str | None None, # 可选查询参数item: Item, # 请求体user: User # 第二个请求体FastAPI会自动处理为多个请求体参数):return {item_id: item_id, q: q, item: item, user: user}再说个容易翻车的点嵌套模型与复杂验证Pydantic模型可以嵌套用来描述复杂数据结构比如订单里有商品列表每个商品又有自己的属性。class Image(BaseModel):url: strname: strclass Item(BaseModel):name: strprice: floattags: list[str] [] # 字符串列表image: Image | None None # 嵌套模型app.post(/items/)async def create_item(item: Item):return item这个工具的选择好比选螺丝刀不是最贵的就好而是最趁手的。Pydantic就是FastAPI生态里最趁手的那把“瑞士军刀”字段类型、默认值、自定义验证器validator一套全齐。第三部分扩展知识——Cookie、Header与其他是不是以为这样就完了餐厅点单还有会员卡和特殊要求呢Cookie 和 Header 参数它们通常用于元数据、身份认证等不直接作为业务参数。在FastAPI中获取它们非常方便。from fastapi import Cookie, Headerapp.get(/)async def read_header_cookie(user_agent: str | None Header(None),session_token: str | None Cookie(None)):return {user_agent: user_agent, session_token: session_token}注意Header会自动将参数名中的下划线_转换为连字符-。比如user_agent会读取User-Agent这个请求头且不区分大小写哦。如果请求头本身就有连字符直接用Header(..., alias...)指定别名。表单数据Form和文件上传File当需要接收HTML表单提交的数据或上传文件时使用。from fastapi import Form, File, UploadFileapp.post(/login/)async def login(username: str Form(...), password: str Form(...)):return {username: username}app.post(/upload/)async def upload_file(file: UploadFile File(...)):content await file.read()return {filename: file.filename, size: len(content)}最后啰嗦一句File和Form参数不能与纯JSON的Body模型混用它们是不同的编码格式。接收文件记得用异步读写大文件更要流式处理别一股脑读到内存里。? 总结与一张速查表好了咱们今天把FastAPI的参数系统彻底捋了一遍。最后送你一张我总结的“参数安置决策表”下次设计接口时拿出来看一眼保准不迷糊路径参数Path用于唯一指定资源。如/users/{id}查询参数Query用于过滤、排序、分页资源列表。如/users?roleadminpage2请求体Body用于创建或更新资源复杂数据。用Pydantic模型。Cookie用于自动携带的会话或身份信息。Header用于元数据、内容协商、认证令牌等。表单Form用于接收HTML表单提交的键值对数据。文件File用于上传文件。姨顺钩摆

相关文章:

Jenkins 学习总结滩

先唠两句:参数就像餐厅点单 把API想象成一家餐厅的“后厨系统”。 ? 路径参数/dishes/{dish_id} -> 好比你要点“宫保鸡丁”这道具体的菜,它是菜单(资源路径)的一部分。 查询参数/dishes?spicytrue&typeSichuan -> …...

macos简单配置openclaw诼

1 实用案例 1.1 表格样式生成 本示例用于生成包含富文本样式与单元格背景色的Word表格文档。 模板内容: 渲染代码: # python-docx-template/blob/master/tests/comments.py from docxtpl import DocxTemplate, RichText # data: python-docx-template/bl…...

Python AI爬虫实战:爬取张雪峰微博并进行情感分析与词云可视化宜

1. 引入 在现代 AI 工程中,Hugging Face 的 tokenizers 库已成为分词器的事实标准。不过 Hugging Face 的 tokenizers 是用 Rust 来实现的,官方只提供了 python 和 node 的绑定实现。要实现与 Hugging Face tokenizers 相同的行为,最好的办法…...

龙芯k - 走马观碑组ST驱动移植柏

正文 异步/等待解决了什么问题? 在传统同步I/O操作中(如文件读取或Web API调用),调用线程会被阻塞直到操作完成。这在UI应用中会导致界面冻结,在服务器应用中则造成线程资源的浪费。async/await通过非阻塞的异步操作解…...

RegisterWriter:ROHM传感器寄存器操作的C++类型安全封装库

1. RegisterWriter 库概述RegisterWriter 是 ROHM 半导体为加速其传感器驱动开发而设计的一套轻量级 C 硬件抽象层(HAL)辅助库,核心定位并非替代标准 MCU HAL(如 STM32 HAL 或 Nordic nRF SDK),而是作为寄存…...

从技术到管理:一名一线开发者的转型心路历程

从技术到管理:一名一线开发者的转型心路历程 在技术行业,许多开发者都曾面临一个关键选择:是继续深耕技术,还是转型为管理者?这条转型之路充满挑战与成长,既是对个人能力的考验,也是对职业规划…...

AI Agent Harness Engineering 的商业化困局:按 Token 计费与按结果付费的博弈

从零破解AI Agent Harness商业化生死门:Token计费惯性与结果付费终局的双向奔赴与博弈深度 副标题:从代码层面解构Agent开发成本模型,从商业落地剖析价值定价逻辑,构建兼顾技术可行性、客户信任度与ROI的可持续盈利体系 第一部分:引言与基础 (Introduction & Foundati…...

多品类迷雾:为何亚马逊店铺无法用“宽泛口号”建立有效定位

当一个品牌或店铺像福特汽车一样,横跨多个品类和型号时,便面临一个根本性的定位困境:它无法在任何一个具体的品类中建立“专家”认知,因此被迫退回到寻找一个覆盖所有产品的“最大公约数”——通常是一个宽泛、无力、难以验证的抽…...

品牌基因烙印:在亚马逊,为何成功的旧名字会成为转型的最大障碍

在商业世界中,一个公司的名字是其最核心的“心智基因”,一旦形成便极难改变。正如“普尔曼”永远让人想起火车车厢,“灰狗”即是长途客运的代名词,即使它们的业务早已多元,巨额的广告也无法扭转公众的固化认知。在亚马逊,这一规律被算法和搜索行为进一步放大:一个在特定…...

无形估值:在亚马逊,为何“公司定位”是你吸引顶级资源的核心资产

“公司的买卖”不仅发生在并购交易中,更持续发生在每一次关键资源向你靠拢的瞬间。在亚马逊的生态中,这表现为:当顶尖人才考虑加入、优质工厂寻求合作、行业资本决定投资、或平台给予流量扶持时,他们本质上都在“购买”你公司未来…...

STM32F1轻量级USB HID键盘鼠标复合设备固件库

1. 项目概述KeyboardMouse 是一个面向 STM32F1 系列微控制器的轻量级 USB HID(Human Interface Device)固件库,专为实现复合型 USB 键盘与鼠标设备而设计。该库不依赖第三方 USB 协议栈(如 ST 的 USB Device Library 或 Keil ARM …...

BMP183气压传感器驱动开发与高精度补偿实践

1. BMP183气压传感器驱动库技术解析与工程实践BMP183是由博世(Bosch)推出的高精度数字气压传感器,广泛应用于无人机高度计、气象站、可穿戴设备及工业环境监测等嵌入式系统中。该器件集成MEMS压阻式压力传感单元、温度传感元件及24位ADC&…...

《空间智能体:下一代AI基础设施》——从视觉识别到空间计算的范式跃迁

《空间智能体:下一代AI基础设施》——从视觉识别到空间计算的范式跃迁摘要(Abstract)近年来,人工智能系统在视觉识别、目标检测与多目标跟踪等任务中取得显著进展。然而,大量研究与工程实践表明,传统基于图…...

KY040旋转编码器驱动详解:消抖、正交解码与多平台适配

1. KY040-rotary 库深度解析:面向嵌入式工程师的旋转编码器驱动实践指南旋转编码器是人机交互中最基础、最可靠的物理输入设备之一,广泛应用于工业控制面板、音频设备音量调节、仪器仪表参数设置等场景。KY-040(亦称 HW-040)作为一…...

SparkFun AVR ISP编程库:嵌入式量产级AVR烧录实现

1. SparkFun AVR ISP 编程库深度解析:面向嵌入式量产的底层ISP烧录实现1.1 库定位与工程价值SparkFun AVR ISP Programming Library 是一个轻量级、零依赖的纯C底层编程库,专为在嵌入式主控(如Arduino兼容板)上实现对AVR微控制器&…...

AVR-IoT Cellular Mini底层技术解析:安全蜂窝连接与低功耗设计

1. AVR-IoT Cellular Mini 开发板底层技术解析AVR-IoT Cellular Mini 是 Microchip 推出的面向蜂窝物联网(Cellular IoT)应用的紧凑型开发平台,其核心价值不仅在于硬件集成度,更在于其构建在 DxCore 基础上的完整 Arduino 兼容软件…...

embeddinggemma-300m入门必看:Ollama一键启动+WebUI交互全流程

embeddinggemma-300m入门必看:Ollama一键启动WebUI交互全流程 1. 快速了解EmbeddingGemma-300m EmbeddingGemma-300m是谷歌推出的开源文本嵌入模型,专门用来把文字转换成数字向量。你可以把它想象成一个"文字翻译官",能把任何文字…...

Linux I/O 演进史:从管道到零拷贝,一篇串起个服务端核心原语右

前言 在使用 kubectl get $KIND -o yaml 查看 k8s 资源时,输出结果中包含大量由集群自动生成的元数据(如 managedFields、resourceVersion、uid 等)。这些信息在实际复用 yaml 清单时需要手动清理,增加了额外的工作量。 使用 kube…...

银行数据中心基础设施建设与运维管理【1.2】

2. 2 数据中心的容量 如何规划数据中心容量一直是数据中心管理者和从业者的一个重大问题。 当一个数据中心建设意向提出之后, 数据中心的建设容量到底该多大? 到底该按照哪些因素去规划数据中心的容量? 数据中心到底该按照那种方式去建设? 如何使将要建设的数据中心能够面…...

Rust的trait关联类型与泛型参数在类型系统表达力上的差异

Rust作为一门现代系统编程语言,其类型系统的设计兼顾了安全性与灵活性。在Rust中,trait关联类型与泛型参数是两种重要的抽象机制,它们在类型系统表达力上各有特点。理解二者的差异,不仅有助于写出更优雅的代码,还能在特…...

Pretext:值得关注的文本排版引擎杆

一、语言特性:Java 26 与模式匹配进化 1.1 Java 26 语言级别支持 IDEA 2026.1 EAP 最引人注目的变化之一,就是新增 Java 26 语言级别支持。这意味着开发者可以提前体验和测试即将在 JDK 26 中正式发布的语言特性。 其中最重要的变化是对 JEP 530 的全面支…...

银行数据中心基础设施建设与运维管理【1.1】

1. 3 银行数据中心建设的基本原则 银行数据中心建设在安全生产前提下的发展趋势是 “高效运行、 节能环保”。 为了充分满足银行 IT 设备数量和管理规范性要求都不断增加的需要, 银行在开展数据中心建设过程中, 必须严格遵循各项技术特性和规范标准要求, 以达到集约化、 模…...

为什么92%的AI语音项目在2026年前将被淘汰?奇点大会首席科学家亲授原生语音迁移倒计时路线图

第一章:AI语音项目淘汰潮的底层归因与奇点临界点判定 2026奇点智能技术大会(https://ml-summit.org) 近年来,全球范围内超63%的中早期AI语音项目在V1.2–V2.0迭代阶段主动终止或被并购清退。这一现象并非源于技术失效,而是由三重结构性张力共…...

TMP117高精度温度传感器驱动开发与I²C寄存器级控制

1. 项目概述SparkFun High Precision Temperature Sensor TMP117 Qwiic 是一款面向嵌入式系统设计的高精度数字温度传感解决方案,其核心器件为德州仪器(Texas Instruments)推出的 TMP117 单芯片温度传感器。该库并非通用型传感器抽象层&#…...

8.2 功能安全 Functional safety:从ASIL到ISO 26262的完整实践指南

1. 为什么功能安全是汽车电子的生命线? 十年前我刚入行时,第一次听说"功能安全"这个概念,以为只是多写几份文档。直到参与某新能源车的紧急制动项目,亲眼看到因为一个电容失效导致系统误触发急刹,才真正理解…...

现代C++智能指针详解

现代C智能指针详解:安全内存管理的利器在C开发中,内存管理一直是程序员需要谨慎处理的难题。传统裸指针容易导致内存泄漏、悬垂指针等问题,而现代C引入的智能指针通过RAII机制为内存管理带来了革命性改变。本文将深入解析智能指针的核心特性与…...

MySQL 查询优化器执行逻辑分析

MySQL查询优化器作为数据库核心组件,其执行逻辑直接影响SQL性能。本文将深入分析其工作原理,帮助开发者理解查询背后的智能决策机制,为高效数据库设计提供理论支撑。查询解析与重写阶段优化器首先对SQL进行词法语法解析,生成语法树…...

从Claude Code源码泄露看AI编码助手设计:12个可收藏的实用模式解析

Claude Code源码泄露揭示了生产级AI编码助手的内部实现。文章重点分析了其背后的12个可复用设计模式,涵盖记忆与上下文、工作流与编排、工具与权限、自动化四大类。这些模式如持久化指令文件、分层记忆、探索-规划-行动循环、上下文隔离子智能体等,为构建…...

【GUI-Agent】阶跃星辰 GUI-MCP 解读---()---决策层兴

先回顾:三次握手(建立连接)核心流程(实际版) 为了让挥手流程衔接更顺畅,咱们先快速回顾三次握手的实际核心,避免上下文脱节: 第一步(客户端→服务器)&#xf…...

MAX31865 RTD测温驱动库:工业级高精度SPI温度采集实现

1. PWFusion_Max31865 库概述:面向工业级 RTD 测温的高精度 SPI 驱动实现PWFusion_Max31865 是一个专为 Maxim Integrated MAX31865 集成电路设计的嵌入式驱动库,核心目标是为 Arduino 兼容平台(包括基于 STM32、ESP32、nRF52 等 MCU 的开发板…...