google-sheets - 如何在 Google 表格的单元格中重复使用相同的公式而无需复制粘贴

标签 google-sheets google-sheets-formula reusability simplify

我正在 Google 表格中使用一个大型(但简单)公式,该公式重复使用相同的公式 block 。为了从一堆不同的选项卡中获取大量数据,我必须在该公式 block 中使用 708 个字符。但随后我需要在 1 个单元格内一遍又一遍地重复引用该数据,这会使公式的长度成倍增加,以至于我什至无法判断发生了什么。

例如,我有一个单元格,其最终代码(包含 2216 个字符)为:

=iferror(IF(ISNUMBER(SEARCH("a",concatenate(TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Brown!$C$3:$C$68&Brown!$D$3:$D$68,Brown!H$3:H$68,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Godoy!$C$3:$C$76&Godoy!$D$3:$D$76,Godoy!H$3:H$76,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Sindel!$C$7:$C$60&Sindel!$D$7:$D$60,Sindel!H$7:H$60,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Taylor!$C$3:$C$82&Taylor!$D$3:$D$82,Taylor!H$3:H$82,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Wanner!$C$3:$C$55&Wanner!$D$3:$D$55,Wanner!H$3:H$55,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Gehrman!$C$3:$C$16&Gehrman!$D$3:$D$16,Gehrman!H$3:H$16,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Francois!$C$3:$C$17&Francois!$D$3:$D$17,Francois!H$3:H$17,"")))))),"A",average(ArrayFormula(mid(concatenate(TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Brown!$C$3:$C$68&Brown!$D$3:$D$68,Brown!H$3:H$68,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Godoy!$C$3:$C$76&Godoy!$D$3:$D$76,Godoy!H$3:H$76,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Sindel!$C$7:$C$60&Sindel!$D$7:$D$60,Sindel!H$7:H$60,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Taylor!$C$3:$C$82&Taylor!$D$3:$D$82,Taylor!H$3:H$82,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Wanner!$C$3:$C$55&Wanner!$D$3:$D$55,Wanner!H$3:H$55,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Gehrman!$C$3:$C$16&Gehrman!$D$3:$D$16,Gehrman!H$3:H$16,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Francois!$C$3:$C$17&Francois!$D$3:$D$17,Francois!H$3:H$17,"")))),sequence(len(concatenate(TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Brown!$C$3:$C$68&Brown!$D$3:$D$68,Brown!H$3:H$68,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Godoy!$C$3:$C$76&Godoy!$D$3:$D$76,Godoy!H$3:H$76,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Sindel!$C$7:$C$60&Sindel!$D$7:$D$60,Sindel!H$7:H$60,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Taylor!$C$3:$C$82&Taylor!$D$3:$D$82,Taylor!H$3:H$82,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Wanner!$C$3:$C$55&Wanner!$D$3:$D$55,Wanner!H$3:H$55,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Gehrman!$C$3:$C$16&Gehrman!$D$3:$D$16,Gehrman!H$3:H$16,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Francois!$C$3:$C$17&Francois!$D$3:$D$17,Francois!H$3:H$17,"")))))),1)*1))),"")

这看起来很长,但这只是因为我使用这个公式(有 708 个字符):

concatenate(TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Brown!$C$3:$C$68&Brown!$D$3:$D$68,Brown!H$3:H$68,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Godoy!$C$3:$C$76&Godoy!$D$3:$D$76,Godoy!H$3:H$76,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Sindel!$C$7:$C$60&Sindel!$D$7:$D$60,Sindel!H$7:H$60,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Taylor!$C$3:$C$82&Taylor!$D$3:$D$82,Taylor!H$3:H$82,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Wanner!$C$3:$C$55&Wanner!$D$3:$D$55,Wanner!H$3:H$55,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Gehrman!$C$3:$C$16&Gehrman!$D$3:$D$16,Gehrman!H$3:H$16,""))),TEXTJOIN("",TRUE,arrayformula(if($B3&$C3=Francois!$C$3:$C$17&Francois!$D$3:$D$17,Francois!H$3:H$17,""))))

在细胞内3次。

是否可以让一个单元格只包含我想要使用的函数 block (作为字符串),然后以某种方式将字符串转换为代码以重用它,而不需要创建一个怪物函数?

例如,我可以分配 A1 来保存我想要多次使用的长代码,然后使用如下公式:

=IFERROR(IF(ISNUMBER(SEARCH("a",textToFormula(A1))),"A",AVERAGE(ArrayFormula(mid(textToFormula(A1),sequence(len(textToFormula(A1))),1)*1)).

我还应该提到,我的工作表中没有足够的空间将我要查找的数据字符串放入单独的单元格中,因为我必须将此公式应用到大约 50 行和 180 列。

最佳答案

哎呀!这是一个很长的公式!遗憾的是,没有像 JavaScript 中那样的 eval(),但我们至少可以为您提供一个更简单的公式。

这个怎么样?它仍然有点长,但远没有那么复杂。它只查询每个工作表一次。这个可以在单元格 F3 中使用,但可以拖动。

=IF(
  JOIN("",{Teacher1!G$7:G;Teacher2!G$7:G;Teacher3!G$7:G;Teacher4!G$7:G;Teacher5!G$7:G})<>"",
  IFERROR(Average(ArrayFormula(--{
    QUERY(ArrayFormula(TO_TEXT(Teacher1!$A$7:$GX)),"select Col"&COLUMN()+1&" where Col3='"&$B3&"' and Col4='"&$C3&"'");
    QUERY(ArrayFormula(TO_TEXT(Teacher2!$A$7:$GX)),"select Col"&COLUMN()+1&" where Col3='"&$B3&"' and Col4='"&$C3&"'");
    QUERY(ArrayFormula(TO_TEXT(Teacher3!$A$7:$GX)),"select Col"&COLUMN()+1&" where Col3='"&$B3&"' and Col4='"&$C3&"'");
    QUERY(ArrayFormula(TO_TEXT(Teacher4!$A$7:$GX)),"select Col"&COLUMN()+1&" where Col3='"&$B3&"' and Col4='"&$C3&"'");
    QUERY(ArrayFormula(TO_TEXT(Teacher5!$A$7:$GX)),"select Col"&COLUMN()+1&" where Col3='"&$B3&"' and Col4='"&$C3&"'")}
  )),"A"),
  ""
)

查询语句:

  • 每个单元格将每个工作表作为表格进行查询,其中名称在工作表中作为一行进行匹配。
  • COLUMN()+1 是让相应的列对齐。 IE。如果我们在 F 列 (6) 中,我们想在 G 列 (7) 中查找。
  • TO_TEXT 允许我们查找非数字(“A”)。

之后,将每个查询结果用--转换为数字,然后取平均值。如果任何数字无法转换为数字,平均值 会给我们一个错误,我们假设该值为“A”

如果日期列中的所有单元格均为空白(空白 JOIN),则完全绕过查询并输出空白单元格。

关于google-sheets - 如何在 Google 表格的单元格中重复使用相同的公式而无需复制粘贴,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63876401/

相关文章:

Java在Android中重用java类

google-sheets - 为Google SpreadSheets中的列生成所有可能的组合

google-apps-script - 类型错误 : Cannot read property "source" from undefined.(第 7 行,文件 "Code")

java - 未经授权收集Google表格信息

javascript - 如何从 Google Sheet App Script 返回#N/A?

java - Java 是否使用字符串实现享元设计模式?

python - 从 Google 电子表格触发 python 代码?

google-sheets - 如何使用 Google 电子表格上的公式复制字符串并附加数字后缀?

google-sheets - Google 表格从单个列中的唯一值获取平均值

jQuery - 有没有办法重用参数来减少代码重复?