我编写了一个脚本,将 ImportXML 公式写入单元格,然后几秒钟后尝试读取单元格并将其替换为它的返回值。
问题是当我用获取的值替换单元格时,我经常(但并非总是)得到#N/A。问题是,我能够在短时间内看到正确的值,因此 ImportXML 可以正确获取并返回该值,但当重写到电子表格时,它就会变得混乱。
示例代码:
myformula = '=ImportXML("http://api.something/01.xml","/offers/price")';
sheet.getRange("A1").setFormula(myformula);
Utilities.sleep(5000);
sheet.getRange("A1").setValue(sheet.getRange("A1").getValue());
我注意到,当最近获取 URL(并由 Google 内部缓存)时,它会获得正确的值。
关于如何解决这个问题的建议?
您的脚本无法接收电子表格已完成重新计算的通知。重新计算所用的时间是不确定的。显然,5 秒的延迟通常就足够了,但有时重新计算需要更长的时间。
Replace sleep()
使用重试循环来延长时间窗口。
myformula = '=ImportXML("http://api.something/01.xml","/offers/price")';
sheet.getRange("A1").setFormula(myformula);
while (sheet.getRange("A1").getValue() === "#N/A") {
Utilities.sleep(5000);
}
sheet.getRange("A1").setValue(sheet.getRange("A1").getValue());
但就像我说的,每次执行时我都会在单元格中看到正确的值,然后在我重写它之后,它会得到#N/A。换句话说,如果我不重写该值,我将在不到一秒的时间内在单元格中看到结果。 –米勒 2013-01-14 19:32
这是云计算现实的一部分。电子表格对象正在更新,并与正在处理原始文件的缓存副本的所有查看者共享。缓存副本与原始副本同步,但这不是即时的。当您查看该工作表时,您就是一名用户。您的脚本正在另一台谷歌服务器上“在云端”执行,虽然它最终会看到与您相同版本的电子表格,但这可能需要一段时间。让两个用户进行更改(您+脚本)需要多次同步操作,因此有时受影响的单元会陷入困境。
有一个开放问题 1131与此类似,评论中有一些解决方法。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)