Flask 学习笔记(四)-参数接收

本文深入讲解Flask框架中参数的使用方法,包括路径参数、位置参数、关键字参数等,探讨了参数的默认值设定、类型转换及约束,如int、float、uuid、any等,并介绍了请求方法的配置和反向解析的实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参数

  1. 路径参数
  • 位置参数
  • 关键字参数
  1. 请求参数
  • get参数在路径中? 之后
  • post参数在请求体

flask中参数

  • 都是关键字参数,没有位置参数
  • 默认标识是尖括号
  • name需要和对应的视图函数的参数名字保持一致
    vi testParams.py
from flask import Flask
app = Flask(__name__)

@app.route("/params/<heh>/")
def params(heh):
    print(type(heh))
    print(heh)
    return "Test Params"

if __name__ == '__main__':
    app.run(debug=True, host='0.0.0.0')

运行后访问http://127.0.0.1:5000/params/lala/
打印结果为: <class ‘str’> lala
可见传递参数默认为字符串类型

  • 参数允许有默认值
    • 如果有默认值,那么在路由中,不传输参数也是ok的
    • 如果没有默认值,参数在路由中必须传递
@app.route("/params/")
def params(heh="123123"):
    print(type(heh))
    print(heh)
    return "Test Params"
  • 默认参数类型是字符串
  • 参数语法 <converter: var>
    • converter类型
    • string 前面所说的默认,会将斜线认为是参数分割符
    • int 约束,限制参数的类型
    • float
    • path 接收到的数据格式是字符串,特性会将斜线认为是一个字符
    • uuid 约束,限制参数为uuid类型
    • any 任意一个,列出的元组中的任意一个
      • 和枚举一个意思
uuid 演示
@app.route("/getuuid/")
def get_uuid():
    return str(uuid.uuid4())

@app.route("/get/<uuid:name>/")
def get(name):
    print(type(name))
    print(name)
    return "Test UUID"

访问http://127.0.0.1:5000/getuuid/随机获取一个uuid:53e8fccf-f238-40a6-af25-1966ad2ea73c
再访问http://127.0.0.1:5000/get/53e8fccf-f238-40a6-af25-1966ad2ea73c/可以看到终端输出
在这里插入图片描述

any 演示
@app.route("/any/<any(c, d, e):name>/")
def any(name):
    print(type(name))
    print(name)
    return "Test Any"

可访问的地址只有“http://127.0.0.1:5000/any/c/“,“http://127.0.0.1:5000/any/d/“,“http://127.0.0.1:5000/any/e/“

  • 请求方法
    • 请求方法并不是像django一样,全部支持的
    • 是需要自己配置请求方法
      • methods=[‘GET’, ‘POST’, ‘DELETE’]
@app.route("/params/<heh>/", methods=['GET'])   #只可使用GET请求
  • 请求工具(测试使用)
    • postman
    • httpie
  • 反向解析
    • url_for 根据endpoint获取到对应的路径
    • endpoint默认就是 函数的名字
    • 如果有参数 url_for(‘函数名’, key=value, key=value)
    • 反向解析在模板中也可以直接使用
from flask import url_for
@app.route("/url/")
def url():
    url = url_for("get_uuid")
    print(url)
    print(type(url))
    
    anyurl = url_for("any", name="c")
    print(anyurl)

    return "Test UrlFor"

访问http://127.0.0.1:5000/url/
在这里插入图片描述
在html模板中可以直接使用

<a href="{{ url_for("get_uuid") }}">get uuid</a>

源码地址:https://github.com/565785929/StudyFlask/tree/master/d04

### 关于江科大 STM32 单片机学习笔记的内容概述 STM32 是一种基于 ARM Cortex-M 系列内核的高性能、低成本、低功耗的 32 位微控制器单元 (MCU),广泛应用于嵌入式系统开发中[^1]。对于希望深入学习 STM32 的开发者来说,江科大的 STM32 学习笔记提供了一套全面而系统的教程资源。 #### 学习笔记的主要内容结构 根据已有参考资料,江科大的 STM32 学习笔记涵盖了多个主题模块,具体如下: 1. **基础概念与入门** - STM32 微控制器的基础架构及其特点。 - 开发环境搭建及相关工具链配置方法[^2]。 2. **串口通信** - USART 数据包处理机制以及 HEX 和文本数据包的发送接收实现方式[^3]。 - 使用 FlyMcu 工具进行固件上传操作说明。 3. **IIC(Inter-Integrated Circuit)协议支持** - IIC 总线基本原理及其实现细节分析。 - 针对 MPU6050 加速度计/陀螺仪传感器设备的具体应用案例研究——包括软件模拟和硬件驱动两种模式下的交互流程设计。 4. **SPI(Serial Peripheral Interface)接口功能探索** - SPI 协议定义及其工作过程解析。 - 结合 W25Q64 NOR Flash 存储器件完成读写测试实验方案描述;同样区分了软硬兼施的不同技术路径探讨。 5. **时间管理相关特性讲解** - Unix 时间戳的概念引入及时区转换算法讨论。 - RTC 实时时钟服务配合 BKP 备份寄存器共同作用下保持断电记忆能力的功能展示。 6. **电源管理和安全防护措施规划** - PWR 模块用于降低能耗水平的技术手段阐述。 - 各类看门狗定时器的工作逻辑解释,保障程序运行稳定性的策略建议。 7. **存储子系统优化指导** - 如何高效访问内部 FLASH 并提取唯一芯片 ID 编号的信息指南。 以下是部分典型代码片段示例供参考: ```c // 初始化USART端口设置函数模板 void USART_Init(void){ GPIO_InitTypeDef GPIO_InitStruct; USART_InitTypeDef USART_InitStruct; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE); // 配置GPIO引脚作为USART复用功能 GPIO_InitStruct.GPIO_Pin = GPIO_Pin_2 | GPIO_Pin_3; GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AF_PP; GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA,&GPIO_InitStruct); // 设置波特率等参数并使能相应中断源 USART_InitStruct.USART_BaudRate=9600; USART_InitStruct.USART_WordLength=USART_WordLength_8b; USART_InitStruct.USART_StopBits=USART_StopBits_1 ; USART_InitStruct.USART_Parity=USART_Parity_No; USART_InitStruct.USART_HardwareFlowControl=USART_HardwareFlowControl_None; USART_InitStruct.USART_Mode=USART_Mode_Rx|USART_Mode_Tx; USART_Init(USART2,&USART_InitStruct); } ``` 上述代码展示了如何初始化一个简单的 USART 接口以便后续可以执行字符流传输任务。 --- ####
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Sajor_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值