我一直在尝试编写一个脚本,根据对某些列的响应,将行从一个工作表复制到另一个工作表。但是,我遇到了检查字符串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来说是全新的,所以这可能只是一个简单的修复,但我不确定。 非常感谢任何帮助。
答案 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
可以解决问题。