我相信你的目标如下。
- 您希望从电子表格的特定列中搜索一个值,并希望检索搜索行的行号。
- 您想使用 PHP 来实现。
问题和解决方法:
在这种情况下,不幸的是,当使用 Sheets API 时,在当前阶段,需要执行以下流程。
- 从您要搜索的工作表中检索所有值。
- 从检索到的值中检索行号和列号。
这可能与您当前的脚本相同。因为在当前阶段,Sheets API 中没有直接搜索值的方法。因此,在这个答案中,作为一种解决方法,我想建议使用由 Google Apps Script 创建的 Web Apps。使用 Google Apps Script 时,可以通过内置方法 TextFinder 检索搜索到的行号。 TextFinder 的处理成本低。所以我提出来了。
用法:
请执行以下流程。
1。创建 Google Apps 脚本的新项目。
Web Apps 的示例脚本是 Google Apps 脚本。所以请创建一个 Google Apps Script 项目。
如果要直接创建,请访问https://script.new/。在这种情况下,如果您没有登录 Google,则会打开登录屏幕。所以请登录谷歌。这样,Google Apps Script 的脚本编辑器就打开了。
需要将此 Google Apps 脚本项目放入您要使用的电子表格的同一 Google Drive。
2。准备脚本。
请将以下脚本(Google Apps 脚本)复制并粘贴到脚本编辑器中。此脚本适用于 Web 应用程序。
function doGet(e) {
const sheet = SpreadsheetApp.openById(e.parameter.spreadsheetId).getSheetByName(e.parameter.sheetName);
const res = sheet.getRange(1, 2, sheet.getLastRow()).createTextFinder(e.parameter.searchValue).findAll().map(r => r.getRow());
return ContentService.createTextOutput(JSON.stringify({rowNumbers: res})).setMimeType(ContentService.MimeType.JSON);
}
3。部署 Web 应用程序。
- 在脚本编辑器上,通过“发布”->“部署为 Web 应用”打开一个对话框。
- 为“执行应用程序为:”选择“我”。
- 为“谁有权访问应用程序:”选择“任何人,甚至是匿名的”。。
- 在这种情况下,不需要请求访问令牌。我认为我建议使用此设置来测试此解决方法。
- 当然,您也可以使用访问令牌。当您使用访问令牌时,请包含 Drive API 的范围之一,例如
https://www.googleapis.com/auth/drive.readonly。
- 另外,我认为键值可以用作查询参数而不是访问令牌。
- 单击“部署”按钮作为新的“项目版本”。
- 自动打开“需要授权”对话框。
- 点击“查看权限”。
- 选择自己的帐户。
- 点击“此应用未验证”中的“高级”。
- 点击“转到###项目名称###(不安全)”
- 点击“允许”按钮。
- 点击“确定”。
- 复制 Web 应用程序的 URL。就像
https://script.google.com/macros/s/###/exec。
- 当您修改 Google Apps 脚本时,请重新部署为新版本。这样,修改后的脚本就会反映到 Web 应用程序中。请注意这一点。
4。使用 PHP 脚本测试 Web 应用程序。
请将您的 Web 应用程序的 URL 设置为以下脚本。并且,请设置电子表格 ID、表格名称。根据您的回复,在此示例中,搜索值和列号分别为 Pj/5678 和 2。 2 of searchColumn 表示“B”列。
<?php
$url = 'https://script.google.com/macros/s/###/exec'; // Please set the URL of Web Apps.
$q = array(
'spreadsheetId' => '###', // Please set the Spreadsheet ID.
'sheetName' => 'Sheet1',
'searchValue' => 'Pj/5678',
'searchColumn' => 2
);
$curl = curl_init();
$option = [
CURLOPT_URL => $url . '?' . http_build_query($q),
CURLOPT_CUSTOMREQUEST => 'GET',
CURLOPT_FOLLOWLOCATION => true,
CURLOPT_RETURNTRANSFER => true
];
curl_setopt_array($curl, $option);
$res = curl_exec($curl);
$obj = json_decode($res);
print_r($obj);
curl_close($curl);
?>
结果:
运行上述脚本时,将返回以下值。返回搜索行的行号。
{"rowNumbers":[###, ###,,,]}
注意:
- 当您修改 Web Apps 的脚本时,请将 Web Apps 重新部署为新版本。这样,最新的脚本就会反映到 Web 应用程序中。请注意这一点。
参考资料: