ГАЗ - Basi c Скрипт - PullRequest
       0

ГАЗ - Basi c Скрипт

0 голосов
/ 14 февраля 2020

Я пытаюсь сделать простой скрипт для перевода всей строки в «Sheet2» каждый раз, когда слово «Correct» вводится в 5-й колонке 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

1 Ответ

2 голосов
/ 14 февраля 2020

Проблема в вашем смещении

Если e.range.columnStart равно 5, тогда e.range.offset(0,-5) будет столбцом 0, что, очевидно, невозможно.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...