“无法读取未定义的属性‘indexOf’”

如何解决“无法读取未定义的属性‘indexOf’”

我正在写一个简单的代码来遍历一个范围内的所有链接,从这些电子表格(链接)中收集信息并粘贴到循环的当前行中。

function UpdateProjects()
{

//----------EDIT THIS FOR A DIFFERENT CLIENT-------------
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var sheet = ss.getSheetByName("Projects");
  var etilastrow = sheet.getLastRow();

  var urlRange = sheet.getRange(2,1,etilastrow);
  var urlsvalues = urlRange.getValues();
  var urls = urlRange.getFormulas();
  Logger.log(urls)

  //looping through all of the rows
  for (var i = 0; i < etilastrow; ++i) {
   currentRow = 2 + i;
  var dirturl = urls[i];
  var remove_before = dirturl[i].indexOf('",');
    var url = dirturl[i].substring(12,remove_before);

Logger.log(currentRow);
    Logger.log(url);

//-----------------Loop code below until last project-------
  var projectPCBdesignsheet = SpreadsheetApp.openByUrl(url).getSheetByName("Main");
    var lstrow = projectPCBdesignsheet.getLastRow(); 

  const vA=projectPCBdesignsheet.getRange(7,2,lstrow).getValues();//get data from project's PCB Design sheet
   
//add last edit values  
  sheet.getRange(currentRow,4).setValue(vA[10]);
  sheet.getRange(currentRow,5).setValue(vA[11]);    

//additional data from PCB design sheet
  sheet.getRange(currentRow,6).setValue(vA[0]);
  sheet.getRange(currentRow,7).setValue(vA[1]);
  sheet.getRange(currentRow,8).setValue(vA[2]);
  sheet.getRange(currentRow,9).setValue(vA[3]);  
  sheet.getRange(currentRow,11).setValue(vA[5]); 
}
}

如果我将 url 硬编码到变量中,脚本就可以工作。现在,从日志中,我可以看到行号和干净的 url。

问题是脚本因此错误而停止: “类型错误:无法读取未定义的属性‘indexOf’ ETI更新项目 @UpdateProjects.gs:18"

如果它向我显示 currentRow 和 url 的日志(位于“indexOf”行之后),我不明白它如何在第 18 行找到错误。

解决方法

问题:

问题 1:

从第二行开始,您会在数据中多出一个空单元格:

var urlRange = sheet.getRange(2,1,etilastrow);

这会给你类似的东西:[[=link],['']]

这可以通过将 etilastrow 更改为 etilastrow-1 来解决。

for 循环中也是如此。

问题 2:

即使您修复了问题 1,当前代码中的主要问题也会产生您所遇到的错误:

var dirturl = urls[i];
var remove_before = dirturl[i].indexOf('",');

请记住,urls 是一个包含 etilastrow 行但只有 一个 列的数组。如果您解释一下您的代码,您所称的本质上就是 urls[i][i]。这将在第二次迭代后返回 undefined,当 i 变为 1 时,因为数据中只有一列。

您的代码有效的原因是因为您在测试它时填充了一个单元格,因此 urls[0][0] 可以正常工作,但是如果您添加更多 URL,第二个索引将增加到超过 0 并且例如,urls[0][1] 将删除并出错,因为 urls 只有一列。

要解决此问题,您可以更改:

var dirturl = urls[i];
var remove_before = dirturl[i].indexOf('",');
var url = dirturl[i].substring(12,remove_before);

到:

var dirturl = urls[i];
var remove_before = dirturl[0].indexOf('",');
var url = dirturl[0].substring(12,remove_before);

改进:

改进 1:

我建议您阅读 for 循环,因为它们在处理索引和数组时可能会令人困惑,并且您需要足够舒适地处理它们。使用 forEachflat() 直接处理每个网址:

  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var sheet = ss.getSheetByName("Projects");
  var etilastrow = sheet.getLastRow();

  var urlRange = sheet.getRange(2,etilastrow-1);
  var urlsvalues = urlRange.getValues();
  var urls = urlRange.getFormulas();


  urls.flat().forEach((r,i)=>{
    let currentRow = i + 2;
    let remove_before = r.indexOf('",');
    let url = r.substring(12,remove_before);
    console.log(url)
    console.log(currentRow)
    // put here the rest of your code
  })

改进 2:

从 Google Apps 脚本的角度来看,多次调用 setValue 并且在 for 循环内调用会消耗大量性能。根据 Best Practices,正确的方法是将值存储在数组中,然后在 for 循环之外使用 setValues。这样,您只需使用一次 setValues

我可以尝试优化您代码的那部分,但答案不会有足够的帮助,因为已经有很多关于此优化的帖子,而且您的代码应该可以使用我指出的更正。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-