微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

重写 Sumproduct 公式去除或忽略字母字符 - VBA 插入

如何解决重写 Sumproduct 公式去除或忽略字母字符 - VBA 插入

我决定重新编写我的问题以简化我所追求的内容。我在 Stack 上遇到了我现在遇到的同样问题的第一篇文章。那时我将所有 INDIRECT 添加到这个原始问题的代码中。
Sum with substitute,ignore and a dynamic range

我一直无法制作链接帖子中提到的“*”通配符。也许非英语 Excel 在这里发挥作用?

以最简单的形式,你能帮我重写这段代码吗(不起作用):

Range("namedRange").FormulaR1C1 = "=SUMPRODUCT(SUBSTITUTE(R10C:R[-1]C,""S"",""""))"

执行以下操作:

  1. blank 替换所有的“S”(“4S”在求和时会读为“4”)
  2. 忽略所有空白单元格和包含除“S”以外的其他文本的单元格。 “4T”应该被忽略。
  3. 对范围内的数字求和
  4. (单元格值永远不会是“4SK”,所以可以失败)

我可能可以编写一个函数来执行上述所有操作。但现在我被卡住了,我的谷歌结果让我变得更聪明了。任何帮助仍将不胜感激

解决方法

根据您编辑的问题进行编辑

我认为 UDF 会更容易维护。

我使用了正则表达式,因为您的要求似乎在发生变化,这将允许在将来更灵活地修改它。

您需要做的就是将要处理的范围作为参数传递给函数;您可以使用 VBA 或直接在工作表上执行此操作。

这是一个返回所有数字单元格或具有单个 showHideModal 的单元格的总和。

如果单元格中可能有多个 S,请将 S 参数更改为 .Global

它允许不连续的范围。

如果您的范围始终是连续的,您可以消除外循环。

True

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。