在Google App Script中使用导入的模块

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在Google App Script中使用导入的模块相关的知识,希望对你有一定的参考价值。

我试图在Google App Script中使用string similarity,但是我不完全清楚如何让它在App Script中运行,我得到多个错误,例如“require”没有定义,另外注意,模块本身出现有一个依赖。

我的最终目标是使用此脚本将一个数组与充满拼写错误的字符串之间的字符串分数匹配到App Script中的正确字符串。这是我失败的代码。

function matchEmails() {   var doc =
 SpreadsheetApp.openById(("ID"));

   var ts = doc.getSheetByName("dir");   var source =
 doc.getSheetByName("data");   var names =
 source.getDataRange().getValues();   var data =
 ts.getDataRange().getValues();   var arr = [];   var arr2 = [];   var
 arr3 = [];   var arr4 = [];
      for (i=0; i<names.length; i++) {

     for (j=0; j<data.length; j++) {

           stringSimilarity.compareTwoStrings(names[i][0], data[j][0]);   Logger.log(stringSimilarity);




       /*
       var n = data[j][0].split();
       for (N=0; N<n.length; N++) {
       arr2.push(n[N].charAt(0));
       }
       var string2 = arr2.join("");
       var arr2 = [];

       if (names[i][0] === data[j][0]) {

       arr.push([data[j][1]]);

       }      */ //I want to replace this blanked out code with String >similarity.      

       if (string === string2) {

         arr.push([data[j][1]]);
         arr3.push([i+1]);
         arr4.push([data[j][0]]);


       }
     }   }   for (i = 0; i<arr.length; i++) {
     source.getRange(arr3[i],6).setValue(arr[i]);
     source.getRange(arr3[i],7).setValue(arr4[i]);   }    }
答案

您的GAS项目不是Node.js应用程序,因此上述操作无效。虽然Google Apps脚本和Node都使用javascript,但它们为执行JS代码提供了不同的运行时环境。在GAS中,环境是Google服务器上的一个封闭的生态系统,最终用户对此一无所知。

在Node中,运行时由V8(JS引擎)和C ++附加组件组成,这些附加组件公开了低级API(访问文件系统等)。您引用的库是为Node.js创建的NPM包。通过NPM安装软件包将使其可用于Node项目,但不要认为它也会神奇地出现在Google服务器上。

您必须使用这些依赖项的特定于GAS的版本,或者,如果它们不存在,则重构源代码以使其与GAS兼容(Node和GAS使用不同的ECMAScript版本,因此一些最新功能(如箭头函数)将破坏您的GAS代码)。

例如,这是GAS https://github.com/oshliaer/lodashgs的lodash

在GAS https://developers.google.com/apps-script/guides/libraries中使用库

附:在GAS中,所有“.gs”文件共享相同的命名空间,因此调用“require”函数是多余的。如果你想模仿这种行为,你仍然需要编写自己的require函数。

另一答案

默认情况下,Google Apps脚本文件可以访问Google API,例如G Suite服务中的电子表格服务:https://developers.google.com/apps-script/reference/spreadsheet/

GAS项目(因此该项目中的脚本)默认情况下不能访问Node.js或任何其他框架。但是,GAS项目可以通过引用作为库包含另一个GAS项目。在GAS脚本编辑器中,使用菜单Resources> Libraries ...通过设置源项目的项目键(以及一些其他源项目属性)将外部GAS项目添加为库。

因此,如果您有一个依赖于require的外部资源(如Node.js)的Javascript,那么如果您能找到一个外部GAS项目,该项目使用相同的API提供相同的服务,您可以将其作为库提供给脚本。您省略了原始脚本中的require语句,因为它们被我提到的GAS库依赖项配置所取代。

如果您的原始脚本及其依赖项都是开源的,则可以为原始文件中的每个级别的依赖项创建GAS项目。您已经可以找到一些流行的JS框架脚本作为GAS库提供。

GAS还允许将外部资源打包为Web应用程序和其他包格式。它们可以与相应的技术一起使用,其中一些已经可以从其他开发人员那里获得。

以上是关于在Google App Script中使用导入的模块的主要内容,如果未能解决你的问题,请参考以下文章

Google App Script在doc中显示提示,但未使用电子表格权限

Google App Script Deploy as Web App 卡在 Fetching Data

Google App Script Regex exec() 仅在一个函数中返回 null

在Google-App-Script for Google云端硬盘中如果标题包含某个字词,如何将某些文件从root移动到某个文件夹?

如何强制 Google App Script MailApp.sendEmail 在循环中为每封电子邮件使用新线程?

如何收听Telegram Bot错误? (Google App Script + Webhooks)