首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >GAS - Basic脚本

GAS - Basic脚本
EN

Stack Overflow用户
提问于 2020-02-14 21:29:59
回答 1查看 33关注 0票数 0

我正在尝试执行一个简单的脚本,每次在Sheet1的第5列键入单词"Sheet2“时,将整行代码转换为”Sheet1“。

下面的代码有什么问题?它不起作用。而且,有时会出现以下错误消息:

代码语言:javascript
复制
ReferenceError: "value" is undefined. (line 2, file "Resize")
代码语言:javascript
复制
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上有相同的功能:

代码语言:javascript
复制
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
EN

回答 1

Stack Overflow用户

发布于 2020-02-14 22:40:33

问题在于你的偏移量

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

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60227319

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档