【发布时间】:2020-02-14 22:40:32
【问题描述】:
每次在 Sheet1 的第 5 列输入“Correct”一词时,我都在尝试编写一个简单的脚本将整行转移到“Sheet2”。
下面的代码有什么问题?它不起作用。而且,有时会出现以下错误消息:
ReferenceError: "value" is undefined. (line 2, file "Resize")
function onEdit(e){
if(e.value != "Correct" || e.range.columnStart != 5) return;
dest = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Sheet2");
e.range.offset(0,-5,1,e.source.getActiveSheet().getLastColumn()).moveTo(dest.getRange(dest.getLastRow()+1,1,1,e.source.getActiveSheet().getLastColumn())); }
如果这有帮助,我在 VBA 上也有同样的功能:
Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Column <> 5 Then Exit Sub
If Target.Value <> "Correct" Then Exit Sub
Dim LR As Long
With Sheets("Sheets2")
LR = .Cells(Rows.Count, 1).End(xlUp).Row
.Cells(LR + 1, 1).Resize(, 4).Value = Cells(Target.Row, 1).Resize(, 4).Value
End With
Rows(Target.Row).Delete
End Sub
【问题讨论】:
-
下面的代码有什么问题?提供minimal reproducible example:提供错误信息并解释发生了什么
-
如果您尝试从编辑器运行它,它会抛出该错误。但是,如果您将第 5 列编辑或更改为“正确”,它应该可以工作