Excel中Lookup函数

#Excel查找函数最常用的是Vlookup,而且是经常用其精确查找。Lookup函数的强大之处在于其“二分法”的原理。

=LOOKUP(查找值,查找区域(Vector/Array),[返回结果区域])

  • 为什么查找区域必须升序/降序?
    理解二分法:
    公式默认查找范围是有序排列,
    公式先拿查找值与表中的最中间的值作比较,如果查找值<中间值,则找表中上半部分中间值再作比较,反之,找下半部分中间值比较,以此往复。
    优点:高效,计算量小;
    缺点:如果查找区域不是按顺序排列的,则只能模糊查找,即使有精确匹配。
    例:查找数字8,先与6对比,比6大,与下半部分对比,1&7,7小于8且最近,所以结果是7;但是当1与7对调位置时,结果就是1。
  • 如果查找不到结果,则会返回一个小于查找值的最大值;
  • 利用上一条原则,我们如果想查找最后一行值(查找值为汉字),且最后一行不断更新,那么思路就是:尽可能找一个排序靠后的汉字(一般选“坐”);
  • 精确查找公式变型:=LOOKUP(查找值,0/(查找区域=查找值),返回值区域),此情况下,返回值区域不可省略;
    分子0可以换成任意自然数吗?
    不能,分子必须小于等于查找值;
    0/(条件区域),如果只有一个真值,那么就会返回一个由{#DIV/0!,0}构成的数组(只有一个0,其他都是#DIV/0),那么查找区域就被锁定为其一行,故而可精准查找,如果分子>查找值,违背了函数定义;当数组中没有符合值时,查询比查找值小的最大值。
  • 当需要满足多个查找条件时,公式变型为:
    =LOOKUP(1,0/(查找区域1=查找值1)*(查找区域2=查找值2),返回值区域)
  • 当1对多查询时(精准查询),为什么只返回靠后的结果?
    见上文“理解二分法”。
### STMH7 SPI 接口使用CubeMX配置方法 #### 使用STM32CubeMX初始化SPI外设 对于STMH7系列微控制器,在使用STM32CubeMX进行SPI接口配置时,可以通过图形化界面简化复杂的寄存器设置过程。启动STM32CubeMX软件后加载目标器件型号,进入Pinout&Configuration页面。 选择要使用的SPI模块(例如SPI1),点击右侧的Configure按钮打开外设参数设定窗口[^2]。在此处指定工作模式为主机或从机;数据帧格式如MSB/LSB优先级、位宽等细节;以及通信速度即波特率因子的选择。另外还需定义NSS信号管理策略,可以选择硬件还是软件控制片选线。 完成上述基本属性调整之后,切换到“Clock Configuration”标签页来优化系统与时钟分配方案以满足性能需求。确保所选定的APB域频率适合于计划中的传输速率,并考虑PLL选项以便获得更精确稳定的源频输出给SPI总线子系统[^3]。 最后一步是在Middleware部分挑选合适的驱动层实现方式—HAL库或是LL低级别函数调用形式取决于项目具体应用场景和个人偏好。当一切就绪之时,“Project Manager”里填写必要的文件保存路径同工程名称即可生成完整的初始化脚本供后续开发环境导入编译链接操作了。 ```c // 自动生成的部分SPI初始化代码片段示意 void MX_SPI1_Init(void) { hspi.Instance = SPI1; hspi.Init.Mode = SPI_MODE_MASTER; hspi.Init.Direction = SPI_DIRECTION_2LINES; hspi.Init.DataSize = SPI_DATASIZE_8BIT; hspi.Init.CLKPolarity = SPI_POLARITY_LOW; hspi.Init.CLKPhase = SPI_PHASE_1EDGE; hspi.Init.NSS = SPI_NSS_SOFT; hspi.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_16; hspi.Init.FirstBit = SPI_FIRSTBIT_MSB; hspi.Init.TIMode = DISABLE; hspi.Init.CRCCalculation = DISABLE; hspi.Init.CRCPolynomial = 10; if (HAL_SPI_Init(&hspi) != HAL_OK) { Error_Handler(); } } ``` 通过以上步骤能够快速建立起基于STM32CubeMX平台上的SPI通讯框架,极大地方便了开发者专注于应用逻辑的设计而不必过分纠结底层硬件抽象层面的问题处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值