【问题标题】:How to reuse same formulas within a cell in Google Sheets without copy pasting如何在不复制粘贴的情况下在 Google 表格的单元格中重复使用相同的公式
【发布时间】:2020-12-31 17:00:53
【问题描述】:

我正在使用 Google 表格中的一个大型(但简单)公式,该公式重复使用相同的公式块。要从一堆不同的选项卡中获取一堆数据,我必须在该公式块中使用 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 次。

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

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

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

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

【问题讨论】:

  • 如果您正在寻找eval,不,没有这样的功能。通常 ArrayFormula hacks 可以得到你想要的。如果您想共享工作表的副本,我可以看看。或者您可以编写一个可以减少重复的应用程序脚本并从您的工作表中调用它。
  • 如果您提供有关您当前情况的更多详细信息,包括电子表格的副本(不含敏感信息),这里的人们可以在这里找到是否适合某些公式修改或 Apps 脚本函数.
  • 主要思想是在每个教师标签中按名字和姓氏搜索学生。然后“主”表将取所有学生分数的平均值。如果任何 1 个班级的缺勤成绩为“A”,则“主”选项卡将显示“A”而不是平均分。这是我不久前制作的旧通用版本:docs.google.com/spreadsheets/d/…
  • @mrmath3 “A”是唯一允许的非数字输入吗?
  • @Calculuswhiz 没错。 “A”是唯一的非数字输入。

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


【解决方案1】:

哎哟!这是一个很长的公式!遗憾的是,在 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")。

之后,将每个查询结果转换为带有-- 的数字,然后取Average。如果任何数字不能转换为数字,Average 会给我们一个错误,我们假设该值为"A"

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

【讨论】:

  • 这个公式很漂亮!
  • 将这个公式放在所有单元格中的问题是,对于“主”选项卡中的每个单独的单元格,当平均值为 0 时(即我们还没有到达那个日期并且是空白的( ) 命令...这会将代码的长度复制 2。有更好的方法吗?
  • @mrmath3 这确实让事情变得棘手。我想我想出了一个聪明的解决方案。它比代码长度加倍略短。您也可以考虑使用命名范围来整理内容。检查编辑的答案。
猜你喜欢
  • 2019-06-04
  • 2023-03-23
  • 2018-05-16
  • 2018-08-21
  • 1970-01-01
  • 2014-06-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多