javascript - 如何根据两个不同列中的两个参数搜索和过滤 Google 表格

标签 javascript html google-apps-script google-sheets

我有一张包含 46 列的工作表,行数不定。我正在寻找一种方法来生成一个具有简单 UI 的 Web 应用程序,该应用程序允许我按两个条件进行搜索并过滤掉所有与这些条件不匹配的结果。第一个是 name/emp# 搜索,分别位于第 3 列和第 4 列。另一个是日期搜索。我的想法是,我可以搜索该日期的该人姓名或号码的所有实例,并将其作为 html 表格或类似的均匀且间隔合理的演示文稿返回。

下面是我目前尝试过的代码。我的知识非常有限,我想了解它是如何工作的,所以保持尽可能简单是理想的选择。我已经能够使用 TextFinder 创建单框搜索,但我听说这可能会很慢,而且这张表可能会很大。我也不知道如何用另一个类别进一步过滤它。我尝试获取第一个文本查找器的结果并通过另一个文本查找器运行它们,但这不起作用。

代码.gs

function doGet() {
  return HtmlService.createTemplateFromFile('index').evaluate();
}

function getValuesFromSS(search) {
  var ss = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Sheet1');
  var lastRow = ss.getLastRow();
  var range = ss.getRange(1,3,lastRow,2); //define range for column D
  var ranges = range.createTextFinder(search).findAll();
  var names = '';
  var nums = '';
  var dates = '';
  var urls = '';

  //loop through each range
  for (i = 0; i < ranges.length; i++) {

    var row = ranges[i].getRow();
    var lastCol = ss.getLastColumn();
    var values = ss.getRange(row, 1, 1, lastCol).getDisplayValues(); //get all values for the row
    var empname = values[0][2]; //column C
    var empnum = values[0][3];  //column D
    var date = values[0][4];  //column E
    var url = values[0][46];

    names+=Utilities.formatString("<td>" + empname + "</td>");
    nums+=Utilities.formatString("<td>" + empnum + "</td>");
    dates+=Utilities.formatString("<td>" + date + "</td>");
    urls+=Utilities.formatString("<td>" + "<a href='https://drive.google.com/uc?export=view&id='" + url + "'>DVIR</a>" + "</td>");
}

return {
  first: names,
  second: nums,
  third: dates,
  fourth: urls
}
}

index.html

<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
  <script type="text/javascript">

    function setPageValues () {
    var search = document.getElementsByName('searchtext')[0].value;
      google.script.run.withSuccessHandler(disp).getValuesFromSS(search);
    }

    function disp(values){
      document.getElementById("results1").innerHTML = values.first;
      document.getElementById("results2").innerHTML = values.second;
      document.getElementById("results3").innerHTML = values.third;
      document.getElementById("results4").innerHTML = values.fourth;
    }
  </script>
</head>
<style>
table {
    border-collapse: collapse;
    }
tr { 
  display: block; 
  float: left; 
  }
td {
    border: 1px solid Black;
    display: block; 
    }
</style>
<body>
<input type="text" name="searchtext">
<input type="button" value="Search" onclick="setPageValues();">
<br>
<div name="resultbox">
<table>
<tr id="results1">
</tr>
<tr id="results2">
</tr>
<tr id="results3">
</tr>
<tr id="results4">
</tr>
</table>
</div>
</body>
<script>
</script>
</html>

以下是示例电子表格链接: https://docs.google.com/spreadsheets/d/1scFOr4nUXwm7brvlMPHFJhyLei3TI-uvoOVugsx-TeA/edit?usp=sharing

正如我所提到的,我想在一个框中搜索名称 - 或 - emp#,在另一个框中搜索日期,并仅过滤与两者匹配的结果以在 html 中显示。谢谢!

最佳答案

  • 您不仅要搜索电子表格中的“驾驶员姓名”和“驾驶员编号”,还要搜索“日期”。
    • 在这种情况下,有时只输入“驾驶员姓名”或“驾驶员编号”。并且存在只输入“日期”的情况。
  • 您希望使用带有 Google Apps 脚本的网络应用来实现此目的。

如果我的理解是正确的,这个答案怎么样?请将此视为多个答案之一。

修改点:

  • 在此修改中,日期输入标记已添加到 HTML 端。
  • 输入“驱动程序名称”/“驱动程序编号”和“日期”后,这些值将作为对象发送到 Google Apps 脚本端。
  • 在 Google Apps 脚本中,使用 TextFinder 搜索这些值。
    • TextFinder 的处理成本低于搜索每一行的处理成本。所以我用来搜索“司机姓名”/“司机号码”和“日期”。

修改后的脚本:

当您的脚本修改时,请进行如下修改。

HTML 端:index.html

从:
function setPageValues () {
  var search = document.getElementsByName('searchtext')[0].value;
  google.script.run.withSuccessHandler(disp).getValuesFromSS(search);
}
到:
function setPageValues () {
  var search = document.getElementsByName('searchtext')[0].value;
  var date = document.getElementsByName('date')[0].value;
  var obj = {};
  if (!search && !date) alert("No search values.");
  if (search) {
    obj.name = search;
  }
  if (date) {
    obj.date = date;
  }
  google.script.run.withSuccessHandler(disp).getValuesFromSS(obj);
}

还有

从:
<input type="text" name="searchtext">
<input type="button" value="Search" onclick="setPageValues();">
到:
<input type="text" name="searchtext">
<input type="date" name="date">
<input type="button" value="Search" onclick="setPageValues();">

Google Apps 脚本端:code.gs

从:
var range = ss.getRange(1,3,lastRow,2); //define range for column D
var ranges = range.createTextFinder(search).findAll();
到:
var ranges = [];
if ("name" in search && search.name != "") {
  ranges = ss.getRange(1, 3, lastRow, 2).createTextFinder(search.name).findAll();
}
if ("date" in search && search.date != "") {
  var dateRanges = ss.getRange(1, 5, lastRow, 1).createTextFinder(search.date).findAll();
  if (ranges.length > 0) {
    ranges = ranges.filter(function(r1) {return dateRanges.some(function(r2) {return r1.getRow() == r2.getRow()})});
  } else {
    ranges = dateRanges;
  }
}
  • 在这种情况下,当 Web 应用程序运行时,您可以看到 2 个输入标签。
    • 仅输入“驾驶员姓名”/“驾驶员编号”时,将显示通过搜索“驾驶员姓名”/“驾驶员编号”检索到的值。
    • 仅输入“日期”时,将显示通过搜索“日期”检索到的值。
    • 当您输入“驾驶员姓名”/“驾驶员编号”和“日期”时,系统会显示通过搜索“驾驶员姓名”/“驾驶员编号”和“日期”检索到的值。

注意:

  • 在此修改后的脚本中,使用您的共享电子表格。请小心这一点。
  • 对于输出,使用了您当前的脚本和格式。

引用:

如果我误解了您的问题并且这不是您想要的方向,我深表歉意。

关于javascript - 如何根据两个不同列中的两个参数搜索和过滤 Google 表格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58441131/

相关文章:

javascript - 谷歌应用程序脚本。检查 Range1 是否与 Range2 相交

javascript - jQuery Mobile 显示双按钮

javascript - 为什么我们要在没有依赖数组的情况下使用 useEffect?

javascript - Joi 验证多个条件

html - 三 Angular 形 div 元素相对于其父元素的大小和位置

html - 我可以使用 :before or :after pseudo-element on an input field? 吗

jQuery 手机 : Grid layouts

javascript - 谷歌文档脚本

javascript - Bootstrap 选项卡中的 Highcharts : non-visible chart breaks on window resize?

c# - 如何在谷歌电子表格中间插入一行