需要帮助调试旨在更新 Google 云端硬盘中数百个文件的 Google Apps 脚本代码

2024-01-11

我工作的公司刚刚更新了其品牌,影响了保存到共享 Google 云端硬盘的数百个 Excel 和 PowerPoint 文件。有一个团队正在努力更新文件。我的挑战是找到一种有效的方法来添加新文件并删除 Google 云端硬盘中的旧文件。

我创建了一个 Google 表格来捕获当前文件 ID、新文件 ID 和文件夹 ID,以及以下 Google Apps 脚本代码。该代码引发以下错误。

异常:获取对象 DriveApp 上的方法或属性 getFileById 时发生意外错误。
批量更新@批量更新.gs:25

希望有人能帮我调试吗?我是一个新手,我已经碰壁了。

function BulkUpdate() {
  
  // This constant is added to updated files
  var success = "Success"

  // Define range 
  var sheet = SpreadsheetApp.getActiveSheet();
  var firstRow = 2; // First row of data to process
  var lastRow = sheet.getLastRow(); // Last row of data to process

  // Fetch range
  var dataRange = sheet.getRange(firstRow, 1, lastRow, 4);

  // Fetch values for each row in range
  var data = dataRange.getValues();
  for (var i = 0; data.length; ++i) {
    var row = data[i];
    var folderId = row[0]; // First column
    var currentFileId = row[1]; // Second column
    var newFileId = row[2]; // Third column
    var confirmation = row[3]; // Fourth column

    // Copy new file to folder and trash current file
    if (confirmation !== success) {
      var currentFile = DriveApp.getFileById(currentFileId);
      var newFile = DriveApp.getFileByID(newFileId);
      var folder = DriveApp.getFolderById(folderId);
      newFile.makeCopy(folder);
      currentFile.setTrashed(true);

      // Update spreadsheet
      sheet.getRange(firstRow + i, 4).setValue(success);
      SpreadsheetApp.flush();
    }
  }
  
  // Create a popup window
  SpreadsheetApp.getUi().alert("Updates Complete");
}

谢谢大家。结果我需要从中减去一lastRow在定义“dataRange”时。下面您将找到最终的代码以供参考。

function onOpen() {
  var sheet = SpreadsheetApp.getActive();
  var menuItems = [{name: 'Update Google Drive', functionName: 'bulkUpdate'}];
  sheet.addMenu('Menu', menuItems);
}

function bulkUpdate() {
  
  // This constant is added to updated files
  var success = "Success"

  // Define range 
  var sheet = SpreadsheetApp.getActiveSheet();
  var firstRow = 2; // First row of data to process
  var firstColumn = 1; // First column of data to process
  var lastRow = sheet.getLastRow(); // Last row of data to process
  var lastColumn = 6; // Last column of data to process

  // Fetch range
  var dataRange = sheet.getRange(firstRow, firstColumn, lastRow - 1, lastColumn);

  // Fetch values for each row in range
  var data = dataRange.getValues();
  for (i = 0; i < data.length; i++) {
    var row = data[i];
    var folderId = row[1]; // Second column
    var currentFileId = row[3]; // Fourth column
    var newFileId = row[4]; // Fifth column
    var confirmation = row[5]; // Sixth column

    // Copy new file to folder and trash current file
    if (confirmation !== success) {
      var currentFile = DriveApp.getFileById(currentFileId);
      var newFile = DriveApp.getFileById(newFileId);
      var folder = DriveApp.getFolderById(folderId);
      newFile.moveTo(folder);
      currentFile.setTrashed(true);

      // Update spreadsheet
      sheet.getRange(firstRow + i, 6).setValue(success);
      SpreadsheetApp.flush();
      continue;
    }
  }
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

需要帮助调试旨在更新 Google 云端硬盘中数百个文件的 Google Apps 脚本代码 的相关文章

  • 如何使用Google脚本获取当前单元格下单元格的值?

    我找不到看起来像这样的选项 var spreadsheet SpreadsheetApp getActive var sheet spreadsheet getActiveSheet sheet getRange sheet getCurr
  • 有没有办法导入/导出容器绑定脚本

    我有一个插件 它使用 appscripts gs 以及 html js 和 css 文件 目前我们所做的是我们有一个参考 Google 文档 其中有一个脚本项目包含所有这些源代码 但是除了手动复制和粘贴之外 没有办法在 GIT 中保留源代码
  • Google 表格 - ARRAYFORMULA 中的 VLOOKUP

    我正在尝试在 Google 表格中的数组公式内进行 Vlookup 我有两张纸 S1 和 S2 每个列都有 3 个相同的列 A 列 日期 B 列 名称 和 C 列 付款类型 我想根据日期和姓名组合匹配将付款类型从表 2 读取到表 1 这意味
  • 使用 Google Advanced Drive 服务通过 Apps 脚本在文件夹中创建新文件

    创建新文件有四种方法 DocsList 显示为DocsList在主列表中 内置于 Apps 脚本中 DriveApp 显示为Drive在主列表中 内置于 Apps 脚本中 驱动器 API 也显示为Drive在主列表中 必须添加到 Apps
  • 使用 google apps 脚本添加大量响应

    我想制作一个脚本 添加大量 大约 1500 简历和候选人信息作为对表单的回复 我有谷歌电子表格的信息 我将其链接到表单 但我只能管理回复 即使我更改电子表格 或添加 表单中也不会发生更新 我正在添加行 但没有添加响应 那可能吗 我看到了 2
  • 使用 google.script.run 从 html 调用库函数

    我使用 Google App Script 实现库 并且使用 google script run 从库中调用函数时遇到一些困难 这是我的图书馆的代码 Code gs function ShowSideBar var html HtmlSer
  • 使用 Google Apps 脚本处理数组中输入元素中的多个文件

    我有一个表单 允许从下拉列表中选择一个项目并上传文件 项目的名称和 ID 保存在电子表格文档中 适用于一个文件 但我想上传多个文件 你能帮我修改一下脚本吗 HTML 部分如下所示 div class col md 4 col sm 6 di
  • Google Sheets - 如何从 iOS 应用程序运行脚本?

    我在电子表格中使用脚本在活动行下方添加行并从活动行复制内容 在 PC 上 我可以通过图像 绘图触发脚本 效果很好 但我不知道如何让它在 iOS 应用程序中工作 其中图像触发不起作用 并且将内容从一个应用程序复制到另一个应用程序是一场噩梦 我
  • 将数据从一张纸复制到另一张纸的APP脚本

    我尝试使用此脚本将数据从一张工作表复制到另一张工作表 但是当我更新源工作表中的数据并运行脚本时 整个数据都会被复制 我只想将更新的数据复制到目标工作表而不重叠 谁能建议该怎么做 function copyPaste var ss Sprea
  • 获取 Google Apps 脚本中新创建的文件夹的 ID

    作为 Google Apps 脚本项目的一部分 我尝试将活动电子表格和几个上传的文件移动到在共享目录中创建的新文件夹中 我已经能够使用以下命令创建新文件夹 DriveApp getFolderById parentFolder create
  • 从 Google 电子表格中的列填充 HTML 下拉菜单

    我是 gs 的新手 所以这应该不难 我有一个 Google 电子表格 其中一列中有值 假设 A 列 我使用 gs 创建了一个自定义菜单 用户将在其中选择一个选项 单击其中一个选项 新组件 将出现一个弹出窗口 其中包含一个下拉菜单 用户应从其
  • 如何编辑范围? // Google Classroom 控制 Google Apps 脚本中学生访问的权限范围

    我是一名高中老师 正在针对 Google Classroom 编写 Google Apps 脚本 我想创建一个类似于学生成绩视图的电子表格 我的学生可以使用他们的凭据进行访问 我已经成功编写了代码 这样我就可以通过在代码中显式放置学生的 I
  • Google Apps 脚本触发器 - 每当将新文件添加到文件夹时运行

    我想在任何时候执行谷歌应用程序脚本new文件被添加到特定文件夹 目前 我使用的是每 x 分钟运行一次的时钟触发器 但我只需要在向文件夹添加文件时运行脚本 有没有办法做到这一点 与this https stackoverflow com qu
  • 在 Google 表格中批量查找并替换正则表达式

    是否有函数 脚本或插件可以将大量正则表达式替换应用于 Google 表格中的一系列数据 我有一张包含地址列表的工作表 另一张工作表在两列中包含几十对正则表达式 例如 St 和 Street 我想替换地址中第一列短语的所有实例列出另一个中相应
  • Google 文档有内容控制吗?

    我对 Google 文档和内容控制有疑问 如果有的话 我们有一个系统 允许用户设计带有内容控件 rtf 文本 组合框等 的 MS Word 文档 并为控件分配一个 ID 以便我们的系统可以提取 ID 并注册答案 然后数据被保存在数据库中 什
  • 阻止用户在共享的 Google 电子表格中创建新工作表

    我创建了一个电子表格 其中除单个单元格之外的所有工作表都受到保护 无法编辑 用户应该在其中输入搜索值 该搜索值会过滤工作表 我共享了启用编辑功能的电子表格 以实现这一点 但这也使用户能够创建新工作表 这是我想阻止的 也许我没有使用最佳的方式
  • 如何让 Google Apps 脚本进行 SHA-256 加密?

    我需要使用文本输入 1 轮 十六进制输出 SHA 256 加密来加密字符串 这应该是一个长度为 64 的字符串 我在 Google Apps 脚本文档中尝试过的每个 SHA 256 加密模块都会返回一组数字 例如 function SHA2
  • getActiveRange 不返回当前选择

    这应该是一个简单的问题 但我自己无法破解 我想将活动工作表中当前选定的单元格复制到名为 data 的数组中 var sheet SpreadsheetApp getActive getActiveSheet var selection sh
  • 在 Google 网站中嵌入 Google 电子表格时,Google Apps 脚本可帮助解决错误?

    电子表格 A 是欢迎新移民来到我们小镇的团队的主数据源 它里面有大量非常敏感的数据 不能公开 哪怕是一点点 我们谈论的是孩子的姓名和出生日期以及他们上学的地方 保证电子表格 A 的安全是至关重要的任务 因此 电子表格 B 使用 import
  • 在 Google Apps 脚本中创建插件

    我已经整理了一些我想在其他 Google 工作表中访问的代码 但是 由于它使用 SpreadsheetApp getUi 因此代码必须绑定到工作表 因此 我决定创建代码作为附加组件 不幸的是 除非我打开应用程序脚本页面 否则附加组件不会出现

随机推荐