- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个脚本过去常常在一分钟内运行。最近我开始收到“超过最大执行时间”错误,表明它现在打破了 6 分钟的限制。
使用“执行记录”,我发现我进行的少数 getValue() 和 getValues() 调用需要很长时间,所以我进行了试验。
以下测试函数需要 3 到 7 秒才能执行:
function test_singleCellRange_getValue() {
var sheet = SpreadsheetApp.getActive().getSheetByName('Marcin');
var range = sheet.getRange(1, 1);
var value = range.getValue();
}
“执行记录”显示 getValue()
调用一直占用时间:
[17-10-29 14:15:00:002 EDT] Starting execution
[17-10-29 14:15:00:019 EDT] SpreadsheetApp.getActive() [0 seconds]
[17-10-29 14:15:00:074 EDT] Spreadsheet.getSheetByName([Marcin]) [0.054 seconds]
[17-10-29 14:15:00:075 EDT] Sheet.getRange([1, 1]) [0 seconds]
[17-10-29 14:15:07:377 EDT] Range.getValue() [7.301 seconds]
[17-10-29 14:15:07:381 EDT] Execution succeeded [7.36 seconds total runtime]
单个单元格包含一个常量字符串值(即没有公式)。 getValue() 的这种糟糕表现是否正常(即期望从 Google 服务器获得的新性能标准),或者我可以做些什么来提高性能?
getValue()
的性能似乎受到电子表格大小的严重影响。尽管上面的代码在单个单元格范围内执行 getValue()
,但它的性能似乎会受到电子表格整体大小的影响。
这毫无意义 - 有人有这方面的经验吗?这是 Google 设计 API 的方式还是一个错误?
最佳答案
使用 Sheets API v4 怎么样?请将此视为几个答案之一。当我在 Spreadsheet 中处理大数据时,由于处理速度,我经常使用 Sheets API。我不知道这个示例脚本是否对您的情况有用。如果这对您没有用,我很抱歉。
此示例脚本可以检索与您的脚本相同的结果。
var sheetId = "### Spreadsheet ID ###";
var range = "Sheet1!A1:A1";
var value = Sheets.Spreadsheets.Values.get(sheetId, range);
// Logger.log(value.values)
要使用此脚本,请按如下方式为高级 Google 服务和 API 控制台启用 Sheets API。
关于google-apps-script - 1 个单元格范围的 Range.getValue() 需要 3 到 7 秒才能执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47003734/
在 FireBaseDp 中检索数据时,可以使用上述方法之一来获取值。我想知道有什么区别(任何优点/缺点)? 最佳答案 确切的行为取决于您提取的数据类型。 如果您要提取字符串值,则两个代码段的行为是相
我在 output1 和 output2 中得到了不同的结果。第一个给了我在注册表中实际看到的值,而后者只给了我默认值。我想念什么? String output1 = Registry.GetValu
我正在使用Kotlin多平台构建iOS框架,除奇怪的问题外,其他一切都运行良好。 来自Kotlin的代码: fun example(): Map { val result = muta
我最近一直在开发一些 JSF 应用程序,并且对 Web 组件 API 的不一致感到不安。 我注意到在服务器端代码中的 JSF 组件对象上调用 .getValue() 或 .getSubmittedVa
我正在开发 JavaFX 表单。该表单应该获取值并将其添加到数据库中。每当我尝试通过 .getValue 获取值时,它都会产生错误 Incompatible Types: Object cannot
我有下面的代码, var data = new Dictionary { { "A1", new TestData { Name = "N1",
返回的错误是: "TypeError: Cannot call method "getValues" of undefined. (line 7, file "Code")" function set
在 Google 表格中,将范围内的数据存储到数组中作为脚本的一部分,然后检查特定列中是否有“Y”,这样我就可以遍历并将这些列存储在新数组中。 我有以下代码,但出现此错误 - “TypeError:无
我正在尝试编写一个通用方法来比较两个对象(我有意引入两种不同的类型。第二个具有与第一个相同的属性。第一个具有更多属性。)。 我想确保属性具有相同的值。以下代码适用于我在对象中拥有的大多数属性,但偶尔会
我写了这门课。这不是原始类的完整描述,为了使我的问题陈述简洁,我给出了所需的内容 template class RB { class Child { members are Child ar
我正在尝试根据我的团队在工作中使用的项目跟踪表来设置电子邮件警报系统。当 K 列中的任务状态更改为“完成”时,我需要它发送电子邮件。我得到了可以在测试表上运行的代码,但是当我将其复制到实时表时, ge
尝试创建获取任何枚举属性值的枚举扩展方法时,我遇到了以下情况: 编译以下代码时,VS 2010 显示错误:“GetValue”方法没有重载需要 1 个参数。注释代码和使用监视工具时 - 该行返回值(见
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我想转换一个 Map>所以它变成了Map .如果它只是 Map在 Java8 中很容易; stream().collect(k -> k.getValue().getMyKey(), Entry::g
我目前正在使用 Scene Builder 制作 javafx 场景。我想以特定格式从日期选择器中获取值。只需使用 datePicker.getValue() 即可以 yyyy-mm-dd 形式返回日
问题是我们无法获取仅存在于具有泛型类型的基类中的字段(非泛型)的值。请看下面的代码片段。呼唤 f.GetValue(a) 将抛出异常消息:后期绑定(bind)操作不能在类型为 Type.Contain
为什么会这样: $RegistryKeys = (Get-ChildItem HKLM:\SYSTEM\CurrentControlSet\services\VMSMP\Parameters\
我试图让我的函数在另一张表的表中查找值。 表格的行用数字标记,但列用字符串命名。 这是我的功能代码 Function GetValue(row As String, col As String)
我试图模拟顶级(不是任何部分的一部分)配置值(.NET Core 的 IConfiguration),但徒劳无功。例如,这些都不起作用(使用 NSubstitute,但它与 Moq 或我相信的任何模拟
我得到了一个代码,它从一个名为频率的列表中获取所有最小值。然后它将最小值与总值的百分比放入一个字符串中。要计算百分比,我想调用 minEntryes.getValue()(minEntryes 是 M
我是一名优秀的程序员,十分优秀!