google sheet string.indexOf('string')没有正确返回

时间:2015-10-01 16:17:26

标签: javascript google-apps-script google-sheets

我一直在尝试编写一个脚本,根据对某些列的响应,将行从一个工作表复制到另一个工作表。但是,我遇到了检查字符串var是否包含另一个字符串var。

的问题
function checkInterest(cell)
{
// assumes source data in sheet named Needed
// target sheet of move to named Acquired
// test column with yes/no is col 4 or D
ss = SpreadsheetApp.getActive()
s = ss.getSheetByName('Form Responses 1');
r = s.getActiveRange();
i = s.getMaxRows();
v = lastValue('P'); 
addByInterest('Lighting','Lighting');
//addByInterest('Sound','Sound');
addHM();
}

function lastValue(column) {
var lastRow = SpreadsheetApp.getActiveSheet().getMaxRows();
var values = SpreadsheetApp.getActiveSheet().getRange(column + "1:" +  
column + lastRow).getValues();

for (; values[lastRow - 1] == "" && lastRow > 0; lastRow--) {}
return values[lastRow - 1];
}

function addByInterest(interest,sheetName)
{
Logger.log(v);
Logger.log('Lighting, Sound'.indexOf('Lighting'));
Logger.log(v.indexOf(interest.valueOf()));
if(s.getName() == 'Form Responses 1' && 
(v.indexOf(interest.valueOf()) >= 0)){
  var row = r.getRow();
  var numColumns = s.getLastColumn();
  var targetSheet = ss.getSheetByName(sheetName);
  var target = targetSheet.getRange(targetSheet.getLastRow() + 1, 1);
  s.getRange(row, 1, 1, numColumns).copyTo(target);
}
}
function addHM()
{
Logger.log('RAN');
if(s.getName() == 'Form Responses 1' && 
 (v.indexOf('Hair') >= 0 || v.indexOf('Makeup') >= 0)){  
  var row = r.getRow();
  var numColumns = s.getLastColumn();
  var targetSheet = ss.getSheetByName('Hair & Makeup');
  var target = targetSheet.getRange(targetSheet.getLastRow() + 1, 1);
  s.getRange(row, 1, 1, numColumns).copyTo(target);
}
}

记录器打印

[15-10-01 12:14:27:346 EDT] [Lighting, Sound]
[15-10-01 12:14:27:346 EDT] Lighting
[15-10-01 12:14:27:347 EDT] 0.0
[15-10-01 12:14:27:348 EDT] -1.0 //Should return greater than or equal to 0
[15-10-01 12:14:27:349 EDT] RAN

我已尝试使用和不使用.valueOf()作为字符串。 JS有点新,对Google Scripts来说是全新的,所以这可能只是一个简单的修复,但我不确定。 非常感谢任何帮助。

1 个答案:

答案 0 :(得分:0)

您不应该使用def some_function(..., is_first=True): if is_first: # code to run the first time else # code to run the other times # recurse some_function(..., is_first=False)

valueOf()会返回一个数组数组,您可以使用.getValues();定位特定的子数组,然后将其分配给return values[lastRow - 1]; - 基于您的代码&#39}。我分享了。

数组值中可能存在前导或尾随空格。在数组v上调用时,查找完全匹配(空白会使其混乱)vs indexOf()对字符串将返回您尝试匹配的字符串的起始位置:

indexOf()

或许[" foo"].indexOf("foo"); // returns -1 due to the leading whitespace " foo".indexOf("foo"); // returns 1 可以解决问题。