- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在编写一个谷歌脚本,不幸的是它运行得太慢了。 (超过 6 分钟限制)。该脚本打开一个文档,替换两个字符串(在谷歌工作表中设置),将其保存为 PDF。没什么特别的。
我有大约 200 个这样的文档要通过这个脚本运行,但在 6 分钟的限制内,它只成功运行了 6 个。谷歌脚本就是这么慢吗,还是我不小心制作了有史以来效率最低的谷歌脚本?
function createAllPDF() {
var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
var range = SpreadsheetApp.getActiveSheet().getActiveRange()
var numRows = SpreadsheetApp.getActiveSpreadsheet().getLastRow() - 1;
for(var i = 9; i <= numRows; i++) {
var thisRange = sheet.getRange("A" + n + ":C" + n);
var fond = thisRange.getCell(1, 1).getValue();
var adresse = thisRange.getCell(1, 3).getValue();
thisRange.setBackground('#cfe2f3');
genDoc(fond, adresse);
}
}
//// CREATE PDF ////////////////// FUNCTION FOR GENERATING THE PDF /////////////////////////////////
function genDoc(fond, adresse) {
// Finds the template and duplicate it into a new file.
var template = ("xxxxxxxxxxxx");
var docId = DriveApp.getFileById(template).makeCopy().getId();
// Opens the newly created Document for editing
var doc = DocumentApp.openById(docId);
var body = doc.getActiveSection();
// Renames the newly generated document
var newName = doc.setName(fond);
// Replaces each with the parsed variables.
body.replaceText("%FOND%", fond);
body.replaceText("%ADRESSE%", adresse);
doc.saveAndClose();
//Adds the PDF ID to the invoice_input sheet
var conv = DriveApp.getFileById(docId);
var pdf = conv.getAs("application/pdf");
var fileId = DriveApp.createFile(pdf).getId();
// Gets the PDF file by ID
var thisPDF = DriveApp.getFileById(fileId);
// The ID of the folder I'd like to put the PDF into.
var folderId = "xxxxxxxxxxx";
// Gets the folder by ID
var targetFolder = DriveApp.getFolderById(folderId);
// Adds the PDF to the Folder
targetFolder.addFile(thisPDF);
// Removes the PDF from the root.
var root = DriveApp.getRootFolder().removeFile(thisPDF);
// Deletes the duplicated document
DriveApp.getFileById(docId).setTrashed(true)
return fileId;
}
任何有关如何优化的指示将不胜感激。我对谷歌脚本和编程非常陌生,所以没什么大不了的,呵呵。如果我错误地使用了该板,请道歉。请告诉我,我会改正。
最佳答案
我立即注意到您有一个 undefined variable n
。它在行中:
var thisRange = Sheet.getRange("A"+ n + ":C"+ n);
这应该会使代码完全无法使用。将这些变量更改为 i
后,我能够成功运行代码整整 6 分钟。在那段时间里,它能够循环大约41.5次。它为第 9-53 行创建了文件,但在能够将最后一个文件添加到正确的文件夹之前停止了。
查看执行记录,最长的操作是创建、移动和删除文件的几次调用。
您还定义了范围
,然后从不使用此变量,从而使其变得不必要。
我按照自己多次使用的结构和方法重写了代码。我能够完全处理第 9-59 行。此方法能够将其扩展 6 行。我建议添加一个超时触发器,每 5 分 55 秒停止该功能,然后 5 秒后再次重新启动。有关 javascript 时间的指南可以找到 here 。我也使用不同的匹配方法;使用正则表达式。有关于正则表达式以及如何最大限度地减少处理时间的广泛指南。我在这方面还远未精通。
function PDFCreator() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var sheet = ss.getSheetByName("Test Sheet");
var lastRow = sheet.getLastRow();
var checkRange = sheet.getRange(9, 1, (lastRow - 8), 3);
var check = checkRange.getBackgrounds();
var lightBlue = "#cfe2f3";
var template = DriveApp.getFileById("1RslWGntAwfLTSytOv_IoOv2_iBhSmsK0ZtEVWaq3ezM");
var folder = DriveApp.getFolderById("0BwZ6LWJudkOHaTFiQjd5cFA5OG8");
for (i = 0; i < check.length; i++) {
if (check[i] == lightBlue) {
continue;
} else {
var dataRow = sheet.getRange((i + 9), 1, 1, 3);
var fond = sheet.getRange((i + 9), 1, 1, 1).getValue();
var adresse = sheet.getRange((i + 9), 3, 1, 1).getValue();
var docName = fond + ".pdf";
var docCopy = template.makeCopy(docName, folder);
var docId = docCopy.getId();
var docToEdit = DocumentApp.openById(docId);
var docBody = docToEdit.getBody();
docBody.replaceText(/\%{1}[F][O][N][D]\%{1}/g, fond);
docBody.replaceText(/\%{1}[A][D][R][E][S][S][E]\%{1}/g, adresse);
docToEdit.saveAndClose();
var fileToPDF = DriveApp.getFileById(docId);
var pdfBlob = fileToPDF.getAs(MimeType.PDF);
var pdfRoot = DriveApp.createFile(pdfBlob).setName(docName);
var pdf = pdfRoot.makeCopy(folder);
pdfRoot.setTrashed(true);
fileToPDF.setTrashed(true);
dataRow.setBackground(lightBlue);
}
}
}
您会注意到我将 for()
和 if()
嵌套在 main 函数中。这样,您就不会在函数之间一遍又一遍地来回传递信息。一般来说,您在循环外部定义的内容越多,您需要进行的调用就越少。我可以在 for 循环外部设置更多变量,以进一步扩展其运行。
基本上,这是一个很长的过程,不可能在 6 分钟内运行 200 次。您可以将其扩展到大约 55/60 行,并且效率完美,但此时您只需要再次运行它即可。
关于javascript - 谷歌脚本运行速度太慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39233844/
我用 cudaMemcpy()一次将 1GB 的数据精确复制到设备。这需要 5.9 秒。反之则需要 5.1 秒。这是正常的吗?函数本身在复制之前有这么多开销吗? 理论上,PCIe 总线的吞吐量至少应为
我正在尝试读取图像的大小并在其高度大于 150 时调整其边距。但是在运行这段代码时,我总是在控制台中得到一个“0”: var coverImg; coverImg =
我正在开发一个 iPhone 应用程序,其中包含一些标准的“相机”功能。保存到相机胶卷真的太慢了,在iPhone 4上大约需要四秒钟。有什么办法可以提高速度吗? 如果您查看默认的 iPhone 相
我创建了一个将图像转换为灰度的类。但它的工作速度太慢了。有没有办法让它运行得更快? 这是我的类(class): @implementation PixelProcessing SYNTHESIZE_S
我使用以下代码,结果是正确的,但 gethostbyaddr 需要大约 30 秒。 function IPAddrToName(IPAddr: string): string; var So
我有以下案例, public class Test { private static final int MAX_NUMBER = 10_00_00; public static vo
我已经正确添加了所有必需的 JARS: Ucanaccess 3.0.4 commons-lang-2.6 commons-logging-1.1.1 hsqldbd jackcess-2.1.3 我
我为特定功能构建了一个多处理密码破解程序(使用单词列表),与使用单个进程相比,它减少了一半的时间。 最初的问题是,它会向您显示破解的密码并终止工作人员,但剩余的工作人员将继续工作,直到他们用完可哈希的
我在我的一个 JSP 中引入了 Sencha 网格。本地 sencha 相当快,但在外部服务器上它太慢了。 我在这里按照部署说明进行操作 http://docs.sencha.com/ext-js/4
我的查询加载时间有很大问题。在这种情况下,我需要 hg_ft_won 列(表:值)中的值,用于 home_team_id 和 away_team_id(表:匹配)。 它确实可以正常工作。加载只需要很长
我现在正在学习不同类型的排序,我发现,从某个点开始,我的快速排序算法根本无法快速工作。 这是我的代码: class QuickSort { // partitioning arr
为什么要模式 [0123]123456|98765 比在 Java 中执行 [0123]123456 然后 98765 慢两倍?所以单独搜索它们比用 OR 执行更快。有人有解释吗? UPD 查看带有结
我有带 Assets 的 Android 应用程序。它们包含 20,000 多个文件,其中大部分是简单的文本或 png 文件,分为不同的文件夹和子文件夹。1 个单个文件的最大大小为 500kb,其中
您好,我在查询中添加了 GROUP_CONCAT 函数,该函数终止了我的查询:/。我的查询是: SELECT u.username,a.user_id,a.id,a.text,a.lang as fr
我正在寻找优化查询的想法。 目前,我有一个 4M 行的表,我只想检索引用的最后 1000 行: SELECT * FROM customers_material_events WHERE refere
我在我的应用程序中使用 NSURLConnection,我在其中扫描条形码,通过 NSURLConnection 发送 XML,Java 服务向我发回 XML。我的问题是,使用 Wifi 时,响应时间
当我运行以下程序时,执行大约需要 7 到 8 分钟。我真的不确定我哪里弄错了,因为这个程序执行起来要花很多时间。 public class Test { public stat
我正在使用 NSFetchResultsController 从数据库中接收项目(有 80.000 个项目)。 这是我的谓词:@"(desc CONTAINS[cd] %@)", [any text]
我在 x_data 中有一个 3x2000 numpy 数组,在 y_data 中有一个 1x2000 numpy 数组,我将其传递给此函数 regress 以给我一条回归线。它工作正常。问题是我正在
我正在做一个项目,我需要改变图像的亮度和对比度,它是亮度而不是亮度。所以我一开始的代码是 for (int y = 0; y (y, x); // read pixel (0,0)
我是一名优秀的程序员,十分优秀!