ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 88|回复: 7

[求助] 提取出关键字含“缺卡”的打卡记录,并把姓名、日期、打卡内容按列放置?

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-10-29 13:35 | 显示全部楼层 |阅读模式
本帖最后由 kangdiwu 于 2024-10-29 13:37 编辑

各位高手,大神,您好!

请问,怎么用函数公式提取出符合关键字含“缺卡”的所有打卡记录,并把相关的姓名、日期、对应内容都提取出来按三列放置?谢谢。
如图和附件,附件excel表里有两个表,一个是原始打卡记录表,另一个是怎样用函数公式提取的表。
image.png image.jpg

钉钉打卡月度汇总_202409.rar

17.88 KB, 下载次数: 19

TA的精华主题

TA的得分主题

发表于 2024-10-29 14:42 | 显示全部楼层
=INDEX(数据源!A:A,SMALL(IF(ISNUMBER(FIND("缺卡",数据源!AJ$5:BM$16)),ROW($5:$16),4^8),ROW(A1)))&""

=DATE(2024,9,MOD(SMALL(IF(ISNUMBER(FIND("缺卡",数据源!AJ$5:BM$16)),ROW($5:$16)/1%+COLUMN(A:AD)),ROW(A1)),100))

=VLOOKUP(A2,数据源!A:BM,MOD(SMALL(IF(ISNUMBER(FIND("缺卡",数据源!AJ$5:BM$16)),ROW($5:$16)/1%+COLUMN(A:AD)),ROW(A1)),100)+35,)

评分

2

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-10-29 14:42 | 显示全部楼层
A2
  1. =IFERROR(INDIRECT("数据源!"&TEXT(ROUNDDOWN(SMALL(IF(ISNUMBER(FIND("缺卡",数据源!$AJ$5:$BN$16)),ROW(数据源!$AJ$5:$BN$16)*100+COLUMN(数据源!$AJ$5:$BN$16),9^9),ROW()-1),-2)+1,"R0C00"),0),"")
复制代码

B2
  1. =IF(A2="","",EOMONTH(RIGHT(数据源!$A$1,10),-1)+MOD(SMALL(IF(ISNUMBER(FIND("缺卡",数据源!$AJ$5:$BN$16)),ROW(数据源!$AJ$5:$BN$16)*100+COLUMN(数据源!$AJ$5:$BN$16),9^9),ROW()-1),100)-35)
复制代码

C2
  1. =IF(A2="","",INDIRECT("数据源!"&TEXT(SMALL(IF(ISNUMBER(FIND("缺卡",数据源!$AJ$5:$BN$16)),ROW(数据源!$AJ$5:$BN$16)*100+COLUMN(数据源!$AJ$5:$BN$16),9^9),ROW()-1),"R0C00"),0))
复制代码

TA的精华主题

TA的得分主题

发表于 2024-10-29 15:12 | 显示全部楼层
=LET(a,LAMBDA(b,TOCOL(IF(ISNUMBER(FIND("缺卡",数据源!AJ5:BM16)),b,x),3)),HSTACK(a(数据源!A5:A16),a(TOROW(TEXT(ROW(INDIRECT(DATE(2024,9,1)&":"&DATE(2024,9,30))),"yyyy/mm/dd"))),a(数据源!AJ5:BM16)))

image.png

TA的精华主题

TA的得分主题

发表于 2024-10-29 15:29 | 显示全部楼层
参与一下,M365 或WPS可用,低版本不适用的

本质上还是一个 二维表转一维表 的需求;
数据源表上没有具体日期,只能是生造了一个数字序列,再用TEXT转为日期格式

一步到位的

=HSTACK(TOCOL(IF(REGEXP(数据源!AJ5:BM16,"下班缺卡",1),数据源!A5:A16,AA),3),TOCOL(IF(REGEXP(数据源!AJ5:BM16,"下班缺卡",1),TEXT(SEQUENCE(,30,45526),"yyyy/m/d"),AA),3),TOCOL(IF(REGEXP(数据源!AJ5:BM16,"下班缺卡",1),数据源!AJ5:BM16,AA),3))





缺卡.png

TA的精华主题

TA的得分主题

发表于 2024-10-29 15:32 | 显示全部楼层
=HSTACK(TOCOL(IF(ISNUMBER(FIND("缺卡",数据源!AJ5:BM16,1)),数据源!A5:A16,NA()),2),TOCOL(IF(ISNUMBER(FIND("缺卡",数据源!AJ5:BM16,1)),数据源!AJ4:BM4,NA()),2),TOCOL(IF(ISNUMBER(FIND("缺卡",数据源!AJ5:BM16,1)),数据源!AJ5:BM16,NA()),2))

TA的精华主题

TA的得分主题

发表于 2024-10-29 16:49 | 显示全部楼层
LET(s,TEXT({1,-1,0},SUBSTITUTE(""""&TOCOL(数据源!A5:A16&";"&TEXT(SEQUENCE(,30,45536),"yyyy/mm/dd")&";"&数据源!AJ5:BM16)&"""",";",""";""")),FILTER(s,ISNUMBER(FIND("缺卡",TAKE(s,,-1)))))

TA的精华主题

TA的得分主题

发表于 2024-10-29 16:50 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-10-30 10:21 , Processed in 0.049895 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表