我正在尝试执行一个简单的脚本,每次在Sheet1的第5列键入单词"Sheet2“时,将整行代码转换为”Sheet1“。
下面的代码有什么问题?它不起作用。而且,有时会出现以下错误消息:
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发布于 2020-02-14 22:40:33
问题在于你的偏移量
如果e.range.columnStart是5,那么e.range.offset(0,-5)将是第0列,这显然是不可能的。
https://stackoverflow.com/questions/60227319
复制相似问题