google-sheets - 编写谷歌表格函数以仅适用于更改的行
问题描述
我最近将 Twilio 与我的一张工作表集成以自动向电话号码发送消息。下面是一个示例过程...
- 电子表格包含数百行,每行都包含 twilio 发送到特定电话号码的特定消息详细信息
- 功能设置为在工作表编辑时触发
- 用户在第 3、59 和 148 行输入一个电话号码,其中包含要发送的唯一消息详细信息
- 函数触发和发送消息
问题是我拥有的功能将在整个工作表中搜索电话号码。我想编写该函数,以便它立即知道哪些单元格已被编辑(使用新的电话号码)并且仅在这些行上运行该函数。因此,与其花 30 分钟梳理每一行寻找电话号码,它只查看那些发生变化的行。
知道我怎样才能做到这一点吗?我到目前为止的功能如下。我知道我需要更改的行,但只是不知道要放置的代码。
function sendSms(to, body) {
var messages_url = "INSERT TWILIO URL HERE";
var payload = {
"To": to,
"Body" : body,
"From" : "(315) 888-4032"
};
var options = {
"method" : "post",
"payload" : payload
};
options.headers = {
"Authorization" : "Basic " + Utilities.base64Encode("PRIVATE INFO")
};
UrlFetchApp.fetch(messages_url, options);
}
function sendAll() {
var sheet = SpreadsheetApp.getActiveSheet();
var startRow = 2;
var numRows = sheet.getLastRow() - 1;
var dataRange = sheet.getRange(startRow, 1, numRows, 2)
var data = dataRange.getValues();
for (i in data) {
var row = data[i];
try {
response_data = sendSms(row[0], row[1]);
status = "sent";
} catch(err) {
Logger.log(err);
status = "error";
}
sheet.getRange(startRow + Number(i), 3).setValue(status);
}
}
function myFunction() {
sendAll();
}
解决方案
推荐阅读
- jestjs - JEST react-testing-library 无法读取未定义的属性“推送”
- highcharts - 折叠/展开子节点
- csv - 如何将 CSV 文件自动导入实体?
- python - Python“int64”无法转换为 MySQL 类型
- android - 为什么我的 RecyclerView 在放置在 AppBarLayout 中时不滚动?
- laravel - 什么是 Laravel Forge > 站点详细信息 > 元 > 标签?
- python - 如何提高 python opencv 的性能?
- asp.net-core - 为什么我的单选列表在模型绑定上转换为多选列表?
- javascript - JavaScript,遍历数组对象
- java - 在 Java 上的 Redis Hash 中列出