【Excel】函数之易踩坑系列(常用函数干货)

2023-10-12 09:40

本文主要是介绍【Excel】函数之易踩坑系列(常用函数干货),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

失效的日期:

数据库导出来的日期通常是字符串格式的!!,超级容易忽略掉的格式问题,成为了统计数目时的一大出错点。

解决办法:用DATE 或 DATEVALUE+MID转化为日期格式

季度和周期的计算公式
  • 【如:第1季度】 =“第”&TEXT((MONTH(A2)+2)/3,“0”)&“季度”
  • 【如:2023/1/2-2023/1/8】=TEXT(A2-WEEKDAY(A2,2)+1,“YYYY/M/D”)&“-”&TEXT(A2-WEEKDAY(A2,2)+7,“YYYY/M/D”)

劝退之老是#N/A的VLOOKUP:

在这里插入图片描述
场景:由于数据库权限问题,重要数据只能导出脱敏文件,需要用到vlookup函数查找另一张源表补全信息。
  然而问题来了:为什么同样的一列,有大部分的单元格能查找到,却有小部分是#N/A(用Ctrl+F是能在两个表都找到的value)呢?
  带着疑惑,我先检查了格式是否相等,再用IF函数验证两个单元格是否相等,答案是TRUE的!!那为什么用VLOOKUP还是找不到呢,我想是出现了薛定谔的格式吧。
  所以我改用了Index函数,结果是理想的,全部都能找到,而且index函数可灵活多了,完全可以代替VLOOKUP。

=INDEX(查询结果!A:B,MATCH(TEXT(F2,“0”),查询结果!A:A,0),2)


强大的COUNTIFS函数:

在这里插入图片描述

场景:统计二级、三级指标完成数量任务,需要用到辅助列+条件列+search函数提取目标列中包含任意关键词的行。
于是乎又臭又长的公式就诞生了(B:B为目标列,F2:F6为条件列):

单条件查询: =IF(ISNUMBER(SEARCH(F2,B2)),1,0)
多条件查询: =IF(SUMPRODUCT(N(NOT(ISERROR(SEARCH(F2:F6,B2))))),1,0)

既然条件列能用通配符,那优化:

单条件查询: =IF(COUNTIF(F2,B2),1,0)
多条件查询: =IF(SUMPRODUCT((COUNTIF(B2,F2:F6))),1,0)

此外,COUNTIFS的其他应用场景:

  • 去重:=IF(COUNTIF(B:B,B2)>1,0,1)
  • 判断该元素是否在另一列出现过:=IF(COUNTIF(B:B,A2),1,0)
  • 分组统计(条件顺序:有重大区分的放在前面)

SEARCH函数的用武之地:

在这里插入图片描述
场景:从字符串中截取关键句,如:把字符串里的日期提取出来、截取包含某个关键字的完整地名。

计算公式: =MID(G2,SEARCH(“保利*”,G2),10)


想用数组就找OFFSET函数:

场景:想返回一组满足多个条件的数组,比如:求出2022年的某个地区的某项指标的中位数。
思路:先利用INDEX+MATCH找到符合条件的单元格组的首格,再用OFFSET返回整个数组,最后用MEDIAN求出中位数。(记得按三键:Ctrl+Shift+Enter)

=MEDIAN(OFFSET(INDEX(数据源!B:H,MATCH(1,(数据源!B:B=B1)*(数据源!D:D=4),0),7),0,0,12,1))


Excel版的case when语句

在这里插入图片描述
场景:根据销售业绩分配不同的提成比例或者根据特定的人给提成。
思路:先用MATCH找到目标值在数组中的位置,再配合CHOOSE返回该位置的值。

=CHOOSE(MATCH(B2,{0,10001,20001,30001}),0.05,0.1,0.15,0.2) # 根据销售业绩分配拟定的提成比例,如:销售额为[0,10000]的提成比例只有0.0.5,大于30000的提成比例有0.2;
=IFERROR(CHOOSE(MATCH(A2,{“小明3”,“小明4”,“小明5”},0),0.1,0.12,0.15),0) # 给特定的员工设置提成比例;


长文本类型数字下拉递增问题

场景:商品的编号通常由字母+10位以上的数字组成,想要在Excel中下拉数字递增是做不到的,因此要借用函数ROW() + 字符串拼接:

=J898615001923000&TEXT(ROW($A1)-1,“00”)

这篇关于【Excel】函数之易踩坑系列(常用函数干货)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/194983

相关文章

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

golang中reflect包的常用方法

《golang中reflect包的常用方法》Go反射reflect包提供类型和值方法,用于获取类型信息、访问字段、调用方法等,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录reflect包方法总结类型 (Type) 方法值 (Value) 方法reflect包方法总结

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

Java easyExcel实现导入多sheet的Excel

《JavaeasyExcel实现导入多sheet的Excel》这篇文章主要为大家详细介绍了如何使用JavaeasyExcel实现导入多sheet的Excel,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录1.官网2.Excel样式3.代码1.官网easyExcel官网2.Excel样式3.代码

python常用的正则表达式及作用

《python常用的正则表达式及作用》正则表达式是处理字符串的强大工具,Python通过re模块提供正则表达式支持,本文给大家介绍python常用的正则表达式及作用详解,感兴趣的朋友跟随小编一起看看吧... 目录python常用正则表达式及作用基本匹配模式常用正则表达式示例常用量词边界匹配分组和捕获常用re

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分