【问题标题】:GAS - Basic ScriptGAS - 基本脚本
【发布时间】: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 列编辑或更改为“正确”,它应该可以工作

标签: excel google-apps-script


【解决方案1】:

问题是你的偏移量

如果e.range.columnStart 为5,那么e.range.offset(0,-5) 将是第0 列,这显然是不可能的。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多