1

我正在尝试粘贴

=IF(AND(C4-C3<($I$1/1000),A4=A3),"OOOO","-----")

进入一个单元格,我通过

 Range("I3").Select
 ActiveCell.FormulaR1C1 = "=IF(AND(C4-C3<($I$1/1000),A4=A3)," & Chr(34) & "OOOO" & Chr(34) & "," & Chr(34) & "-----" & Chr(34) & ")"
 Range("I3").Select

返回运行时错误“1004”应用程序定义或对象定义错误

我已经尝试过双引号并看到 & Chr(34) & 解决方法并尝试过。没有任何效果。此外,一些简单的事情

 ActiveCell.FormulaR1C1 = "=IF("

不起作用,但是

 ActiveCell.FormulaR1C1 = "=IF" 

做。

奇怪的是,这在代码中有效

Range("C3").Select
ActiveCell.FormulaR1C1 = "=MID(B3,1,2)*3600+MID(B3,4,2)*60+MID(B3,7,9)"
Range("C3").Select

我之前做的。如果我将 "=MID(B3,1,2)*3600+MID(B3,4,2)*60+MID(B3,7,9)" (而不是我尝试使用的字符串)粘贴到调试时出现问题代码并点击继续,它将粘贴该行,因此在两个语句之间不会发生任何事情。只有一些选择和复制/粘贴之间会发生什么,但如果你想看的话,我还是会把它包括在这里

    Range("C3").Select
  ActiveCell.FormulaR1C1 = "=MID(B3,1,2)*3600+MID(B3,4,2)*60+MID(B3,7,9)"
Range("C3").Select
Selection.Copy
Range("D3").Select
Selection.End(xlDown).Select
ActiveSheet.Paste
Range("K3:Z4").Select
Application.CutCopyMode = False
Selection.Copy
Range("K1").Select
ActiveSheet.Paste
Columns("H:H").Select
Application.CutCopyMode = False
Selection.Cut
Columns("M:M").Select
ActiveSheet.Paste
Columns("I:I").Select
Selection.Cut
Columns("H:H").Select
ActiveSheet.Paste
Range("I3").Select
ActiveCell.FormulaR1C1 = "=IF(AND(C4-C3<($I$1/1000),A4=A3)," & Chr(34) & "OOOO" & Chr(34) & "," & Chr(34) & "-----" & Chr(34) & ")"
Range("I3").Select
4

2 回答 2

4

快速回答:

您需要将公式更改为 R1C1 样式 - 或者更简单,将公式分配给.Formula而不是.FormulaR1C1属性。

更长的解释:

Excel 有两种引用单元格的方式:

  1. 默认的A1表示法,您通过提供列字母和行号来引用单元格 - 并通过前缀 a 将其固定为行或列$
  2. R1C1表示法,通过指定单元格的行和行号以及列和列号来引用单元格。如果数字在括号中提供,则引用是相对的,没有括号是绝对的。要使用此表示法,您需要在 Excel 选项(在公式下)中设置它RC[]

R1C1表示法的优点是相对引用在应用于多个单元格时不会改变!例如,=A1+B1在 C1 中输入的 A1 公式将是=RC[-2]+RC[-1]。如果现在将公式复制到 C 列下,则行号将在A1样式中的每一行中更改(例如=A2+B2=A3+B3等)。在R1C1表示法中,它是完全相同的公式,没有任何变化。

在普通的 Excel 用户界面中,这无关紧要,只是一个偏好问题,因为只要您使用$.*正确修复绝对引用,Excel 就会自动调整公式

但是,如果您想搜索和替换引用,它在宏中变得更加有用!想象在上面的例子中,你想把公式从 更改=A1+B1=A1+A2- 在任何地方使用这个公式。在A1中,您不能简单地用 A2 搜索和替换 B1,因为 B1 将变为 B2、B3 等等。但是,在R1C1RC[-1]中,您只需重新使用即可R[1]C

出于这个原因,Excel 宏记录器还会记录R1C1中的公式- 无论您将其应用到何处,它都是相同的公式!但是,每个Range都有一个.Formula和 一个FormulaR1C1您可以设置的属性 - 另一个属性将相应地更新。因此,请使用适合您需要的任何样式。

在您的情况下,如果您打算将R1C1公式也用于 I3 以外的其他单元格,则它是有意义的。

A1

Range("I3").Formula = "=IF(AND(C4-C3<($I$1/1000),A4=A3),""OOOO"",""-----"")"
Range("J4").Formula = "=IF(AND(D5-D4<($I$1/1000),B5=B4),""OOOO"",""-----"")"

R1C1

strFormula = "=IF(AND(R[1]C[-6]-RC[-6]<(R1C9/1000),R[1]C[-8]=RC[-8]),""OOOO "",""-----"")"
范围(“I3”).FormulaR1C1 = strFormula
范围(“J4”).FormulaR1C1 = strFormula

( * 有趣的边节点:在 Excel 的第一个版本中,Microsoft 使用R1C1作为默认符号,因为它在多个方面优于A1。但是,由于当时 Lotus 1-2-3 是标准并且A1已经被接受作为规范,它在以后的版本中恢复了这种表示法。)

于 2013-01-30T22:41:34.973 回答
0

您的问题是使用.FormulaR1C1而不是使用R1C1样式的公式。

如果您查看电子表格,您会看到 C3 包含

=MID('B3',1,2)*3600+MID('B3',4,2)*60+MID('B3',7,9)

因为它翻译了你对字符串的引用,而 reeor 指的是它试图用它不理解的公式引用一个单元格。

要使用 B3(和 C3,以及其他),您需要使用.Formula

ActiveCell.Formula = "=MID(B3,1,2)*3600+MID(B3,4,2)*60+MID(B3,7,9)"
ActiveCell.Formula = "=IF(AND(C4-C3<($I$1/1000),A4=A3)," & Chr(34) & "OOOO" & Chr(34) & "," & Chr(34) & "-----" & Chr(34) & ")"
于 2013-01-30T21:21:57.977 回答