google-apps-script - 扫描数据后自动推进单元格
问题描述
我希望我的谷歌表格在使用条形码扫描仪扫描数据后自动推进单元格,而不是每次都按 Enter 键。
在参加课后会议时,我正在使用条形码扫描仪来收集学生证。条形码扫描仪拿起他们的身份证,我复制了一些为其加盖时间戳的脚本。但是,要前进到下一个单元格,您必须在每次扫描时按 Enter。我希望每次扫描 ID 后工作表都会自动前进。脚本的第一部分是时间戳。第二部分是我试图写一个时间触发器。
完全披露,我不是编码人员,我的知识非常有限。任何帮助,将不胜感激。
function onEdit(event)
{
var timezone = "GMT-5";
var timestamp_format = "MMM-dd, hh:mm"; // Timestamp Format.
var updateColName = "Scan";
var timeStampColName = "Scan Sent";
var sheet = event.source.getSheetByName('Sheet1'); //Name of the sheet where you want to run this script.
var actRng = event.source.getActiveRange();
var editColumn = actRng.getColumn();
var index = actRng.getRowIndex();
var headers = sheet.getRange(1, 1, 1, sheet.getLastColumn()).getValues();
var dateCol = headers[0].indexOf(timeStampColName);
var updateCol = headers[0].indexOf(updateColName); updateCol = updateCol+1;
if (dateCol > -1 && index > 1 && editColumn == updateCol) { // only timestamp if 'Last Updated' header exists, but not in the header row itself!
var cell = sheet.getRange(index, dateCol + 1);
var date = Utilities.formatDate(new Date(), timezone, timestamp_format);
cell.setValue(date);
}
}
function createTimeDrivenTriggers() {
// Trigger every 6 hours.
ScriptApp.newTrigger('myFunction')
.timeBased()
.everySec(1)
.create();
}
我希望谷歌表格在有人扫描他们的 ID 后自动推进单元格。
解决方案
也许最简单的方法是将条形码扫描仪配置为将回车字符添加为它发送的最后一个字符?
由于我不知道您使用的是哪个品牌或型号,因此我发布了几个示例:
另一种解决方案是使用条形码扫描仪扫描每个学生 ID 代码后的附加代码。此附加代码将仅包含回车符(回车)。发布一个例子:
推荐阅读
- azure - 资源创建屏幕显示我的 Azure 订阅已禁用,即使它不是
- python - 无法理解如何在 django 模板中注入 crisp_form 标签
- java - 构建失败错误:java:USFW_UNSYNCHRONIZED_SINGLETON_FIELD_WRITES 如何修复现场错误报告的问题
- mongodb - 无法使用 MongoDB Compass 在 mongodb 中搜索特定日期
- android - 如何在标签布局中添加菜单
- python - 使用 Dash 和 Plotly、Python 快速可视化大表的方法
- jenkins - 在 Jenkins 中使用主动选择参数更新按钮
- statistics - 为什么这个随机分布的平均值为 0?
- kotlin - 使用 kotlin 协程时使用 try catch 块吞下异常
- typescript - 无法解析 Nest.js 中的模块依赖关系