我希望编写一个宏来为我完成一项非常重复的任务,但进入 VBA 比预期的要难。当我有时间的时候,我会学习如何为 excel 编写宏,因为它看起来非常有用,但是我这周不能花 5 到 12 个小时。
也许这里有人可以提供帮助!
我有一些遵循这种模式的 excel 文件:
Column C - Column D
--------------------
text | (empty)
number | (empty)
number | (empty)
text | (empty)
number | (empty)
text | (empty)
text | (empty)
number | (empty)
text | (empty)
number | (empty)
文本和数字在几千个单元格中随机交替。我需要 D 列保存,当 C 列是数字时,与前一个数字的差值,否则它必须保持空白:
Column C - Column D
--------------------
text | (empty)
3 | (empty)
14 | (=C3-C2) : 11
text | (empty)
16 | (=C5-C3) : 2
text | (empty)
text | (empty)
21 | (=C8-C5) : 5
22 | (=C9-C8) : 1
所以算法是:
var previousNumberCell
var i = 1
for all (selected) cells/rows
if (Row(i).column(C) holds number) {
Row(i).column(D).value = "=C"+i+"-"C"+previousNumberCell
previousNumberCell = i;
}
i++
End
我不在乎第一个或最后一个单元格是否不起作用。
非常感谢您的帮助,或者如果您能指出我在哪里可以找到答案。
编辑:这是问题的简化版本,有两件事我不知道如何使用 excel 宏做得好:选择一个单元格,并判断单元格是否为数字...作为记录,数字单元格已被转换从文本到数字格式。