我需要一个数组公式,该公式需要从Sheet1获取一定长度的数据行。对于该行,在每个不空白的列中,我需要获取该列的Sheet1标头值,并将该数据显示在Sheet2上的连续行中(该行的单元格之间没有任何空格)。
我在工作表1上有一张数据表(雇员和行业证书,失效日期是该表的单元格数据),电子表格正在跟踪的每位员工都有一行。认证是专栏。
我们正在使用此信息链接到ID徽章打印机软件(Bodno Silver),在此我们仅限于将数据列链接到特定的文本框。
问题在于并非每个人都拥有所有认证。这些行上用空格隔开,以分隔每位员工所拥有的证书。在徽章软件模板中设置所需的文本框时,每个文本框都链接到一个特定的列,我很快意识到,如果不是每个人都使用此数据,那么每个人都会获得所有认证,因此在它们之间会有很多奇怪的空白。列出的认证而不是连续的列表。
我对此的解决方案(除了“使用更好的软件”以外,如果有人知道的话,我会向更好的人开放),是创建一个新的工作表和数组公式,除了我和其他人,其他人不会使用id打印机软件。该工作表将具有类似的数据表,该数据表将在到期日期之间散布有空白单元格的数据行,并将其中具有日期的单元格的匹配列标题放入具有相同最大长度的连续行中(消除了空白单元格) )。
从本质上讲,这将使我能够规避徽章软件的限制,并且每个文本框都将是MatertCert1,MatchedCert2,MatchedCert3等,最多达到原始的最大证书数量。
在解释我要去的事情方面,图片可能比我的文字更好。
我做了一段时间。我认为这将是一个简单的INDEX,MATCH,ISBLANK公式(我可以使用适当的相对和绝对单元格链接来创建),然后扩展到整个表格,变成巫婆狩猎,而我为所有这些为自己的罪过祈祷可能是圣洁的。还有很多谷歌搜索...。我很快意识到,毕竟这可能不是那么简单。
最后,我得出了以下两个数组公式,以便正确显示我要做什么:
{=IFERROR(INDEX(Sheet1!$E$2:$P3,1,MATCH(FALSE,ISBLANK(Sheet1!E3:Q3),0)),"")}
(足够容易,对吧?我想是这样...)
在对此进行思考之前,我一直在努力思考使公式具有通用性所需的条件,以便可以在整个表格中使用它。
我只是公开发布以下内容而感到肮脏,但是这里...
{=IFNA(INDEX(INDIRECT(ADDRESS(ROW($E$2),(MATCH(E3,Sheet1!$2:$2,0)+1),1,1, "Sheet1")&":"&ADDRESS(ROW(E3),COLUMN($Q3),1)),1,MATCH(FALSE, ISBLANK(INDEX(INDIRECT("Sheet1!"&ADDRESS(ROW(E3),(MATCH(E3,Sheet1!$2:$2,0)+1),1)&":"&ADDRESS(ROW(E3),COLUMN($Q3),1)),0,0)), 0)),"")}
(请不要报警...)
[忍者编辑]尽管此数组公式适用于从第二列到最后一列的结果,但如果结果范围后没有空白列,则该列公式将不起作用。实际的电子表格具有水平运行的4个不同的认证组,但是我能够轻松地在另一张工作表的相应数据中添加空白列,因此我就放任不管了。我会为某人提供答案,以解释为什么这里也是这种情况[/ edit]
第一个数组公式以及使用ISBLANK的INDEX MATCH非常简单。
对我来说,最大的问题是,为什么第二个数组公式需要嵌套在ISBLANK函数内部的附加INDEX函数,所以让我连续几天疯了。
将功能拆开并进行实验时,我意识到,如果ISBLANK函数内部具有任何INDIRECT引用,而ISBLANK函数本身就是MATCH函数内部,则匹配结果为 ALWAYS 1:
{=MATCH(FALSE,ISBLANK(INDIRECT("$E3:$Q3")), 0)}
上面的 ALWAYS 总是返回1,而如果我将范围显式放入,则该功能就可以正常工作。这不是我的选择,因为我需要使用上一个单元格的地址动态返回比赛的起始位置。
但是,添加INDEX函数(列和行值为0)以封装INDIRECT函数可以提供正确的答案。我只是通过反复试验才弄清楚了。
能不能让更多知识的人让我知道是什么原因造成的?
作为一个更广泛的问题,考虑到我仅限于使用公式(无VBA),我还想知道我是用错误的方式进行操作还是是否有更简单的方法来完成此操作这个没有公式的庞然大物吗?
我知道这张纸可能会在一年内需要维护-祝自己好运!
答案 0 :(得分:3)
将此内容放入E3,上下复制
=IFERROR(INDEX(Sheet1!$2:$2,AGGREGATE(15,6,COLUMN(INDEX($E:$P,MATCH($C3,Sheet1!$C:$C,0),0))/(INDEX(Sheet1!$E:$P,MATCH($C3,Sheet1!$C:$C,0),0)<>""),COLUMN(A:A))),"")
关于您的公式为何无效的原因,它太复杂了,无法解析。请注意,除非工作表是变量,否则应尽可能避免INDIRECT。几乎可以始终在其位置使用INDEX。
INDIRECT和ADDRESS都是易失性函数。每次Excel重新计算时,易失函数都会重新计算,从而导致许多不必要的计算。
答案 1 :(得分:1)
不是解决方案,而是回答为什么您会看到此行为:
编辑:以前的解释只是简单的错误
这让我感到困惑,所以我做了一些调查:
我认为您的问题实际上是由ISBLANK函数引起的,因为它打算与单个值一起使用,并且不能处理范围。当将空白返回到(或显示在)工作表上时,由函数返回的任何空白都只会转换为数值(0)。如果该函数返回到另一个函数,则似乎保留了BLANK值。
编辑:添加无矩阵公式的解决方案
这可能比使用数组公式更复杂...但是我强烈不喜欢它们,所以我会尽力删除它们。
首先,我将在结果表中的位置添加一个索引:
=IF(F$7>COUNTIFS($F3:$L3,"<>"),
"",
IF(
MINIFS(
$F$7:$L$7,$F$7:$L$7,
">" & IFNA(INDEX($F$7:$L$7,MATCH(E9,$F$2:$L$2,0)),0),
$F3:$L3,
"<>"
)=0,
"",
INDEX(
$F$2:$L$2,
MATCH(
MINIFS(
$F$7:$L$7,$F$7:$L$7,
">" & IFNA(INDEX($F$7:$L$7,MATCH(E9,$F$2:$L$2,0)),0),
$F3:$L3,
"<>"
),
$F$7:$L$7,
0
)
)
)
)
基本上,该公式查看上一个单元格中的证书,然后查找大于该值的下一个最小索引。