0

0

如何为特定工作表的编辑操作添加唯一时间戳(仅限“Verify”表的第9列)

花韻仙語

花韻仙語

发布时间:2026-01-09 15:21:39

|

851人浏览过

|

来源于php中文网

原创

如何为特定工作表的编辑操作添加唯一时间戳(仅限“Verify”表的第9列)

本文详解如何修正google sheets脚本中跨工作表误触发时间戳的问题,通过精准限定工作表名称和编辑范围,确保仅当“verify”表第9列被编辑时,才在对应行第11列写入首次时间戳。

原始脚本的核心问题在于:e.source.getSheetByName("Verify") 强制将 sh 指向“Verify”工作表,但后续判断未校验当前被编辑的工作表是否就是“Verify”。因此,无论你在“Example Sheet”“Data”还是任意其他表中编辑第9列,脚本都会获取该编辑事件的行号(如第89行),然后直接往“Verify”表的第89行第11列写入时间戳——这显然违背了业务逻辑。

✅ 正确做法是:先确认编辑发生在目标工作表("Verify"),再执行时间戳逻辑。需同时满足三个条件:

  • 编辑列是第9列(col === 9);
  • 当前激活工作表名称为 "Verify"(e.source.getActiveSheet().getName() === 'Verify');
  • 目标时间戳单元格(第11列同行列)当前为空(!stampCol.getValue()),确保仅首次编辑生效。

以下是修复后的完整脚本:

function onEdit(e) {
  var sh = e.source.getActiveSheet(); // 获取实际被编辑的工作表,而非硬编码
  var row = e.range.getRow();
  var col = e.range.getColumn();

  // 仅当编辑发生在"Verify"表、且是第9列时继续
  if (col === 9 && sh.getName() === 'Verify') {
    var stampCol = sh.getRange(row, 11); // 在同一张表内定位第11列
    if (!stampCol.getValue()) { // 确保该单元格尚未打过时间戳
      var tz = e.source.getSpreadsheetTimeZone();
      var date = Utilities.formatDate(new Date(), tz, 'dd-MM-yyyy hh:mm:ss');
      stampCol.setValue(date);
    }
  }
}

? 关键改进说明

ChartGen
ChartGen

AI快速生成专业数据图表

下载
  • ✅ getActiveSheet() 动态获取真实编辑源表,避免跨表污染;
  • ✅ sh.getName() === 'Verify' 作为前置守卫条件,彻底隔离非目标表的编辑事件;
  • ✅ stampCol 基于 sh(即当前表)获取,逻辑自洽,不再跨表读写;
  • ✅ 时间格式保留 'dd-MM-yyyy hh:mm:ss',符合原文需求;手动清空整列即可重置每日状态。

⚠️ 注意事项

  • onEdit 触发器对单元格批量粘贴、公式重算、脚本批量修改等不响应,仅响应用户手动编辑;
  • 若需支持多语言/多时区协作,建议改用 Session.getScriptTimeZone() 替代 getSpreadsheetTimeZone() 以保持一致性;
  • 部署为“标准触发器”即可,无需额外安装;但请确保脚本项目已绑定至目标电子表格。

该方案简洁、健壮、可维护,完美实现“仅 Verify 表第9列编辑 → 同行第11列首次写入时间戳”的核心需求。

相关专题

更多
session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

307

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

735

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

88

2025.08.19

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

公务员递补名单公布时间 公务员递补要求
公务员递补名单公布时间 公务员递补要求

公务员递补名单公布时间不固定,通常在面试前,由招录单位(如国家知识产权局、海关等)发布,依据是原入围考生放弃资格,会按笔试成绩从高到低递补,递补考生需按公告要求限时确认并提交材料,及时参加面试/体检等后续环节。要求核心是按招录单位公告及时响应、提交材料(确认书、资格复审材料)并准时参加面试。

37

2026.01.15

公务员调剂条件 2026调剂公告时间
公务员调剂条件 2026调剂公告时间

(一)符合拟调剂职位所要求的资格条件。 (二)公共科目笔试成绩同时达到拟调剂职位和原报考职位的合格分数线,且考试类别相同。 拟调剂职位设置了专业科目笔试条件的,专业科目笔试成绩还须同时达到合格分数线,且考试类别相同。 (三)未进入原报考职位面试人员名单。

52

2026.01.15

国考成绩查询入口 国考分数公布时间2026
国考成绩查询入口 国考分数公布时间2026

笔试成绩查询入口已开通,考生可登录国家公务员局中央机关及其直属机构2026年度考试录用公务员专题网站http://bm.scs.gov.cn/pp/gkweb/core/web/ui/business/examResult/written_result.html,查询笔试成绩和合格分数线,点击“笔试成绩查询”按钮,凭借身份证及准考证进行查询。

8

2026.01.15

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

65

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

36

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 3.8万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号