gpt4 book ai didi

javascript - 谷歌脚本 : Delete row if a value in it exists in another sheet

转载 作者:行者123 更新时间:2023-11-29 19:42:41 24 4
gpt4 key购买 nike

我对 Google Scripting 有疑问。我今年 2 月才开始使用 Google Script,所以我还没有深入了解它。不管怎样,我的问题是:

如果某行的某些值存在于另一个工作表中,我可以删除该行吗?我尝试了在互联网上找到的几个概念,但无法想出一个有效的函数。

这是 Google Doc详细查看。

例如,在工作表 1 中我有两行:


姓名 |地点 |年龄

卡尔 |佛罗里达 | 45

迈克 |佛罗里达 | 41


在工作表 2 中:


姓名 |地点 |年龄

迈克 |佛罗里达 | 41


脚本应该删除工作表 1 中的 Mike Florida 行,因为它在工作表 2 中有重复数据。所以基本上,如果工作表 2 中的数据存在于工作表 1 中,则应该在工作表 1 中删除它。但棘手的部分是,我必须只比较第 1 列和第 2 列。第 3 列不重要。如果工作表 2 中的第 1 列和第 2 列与工作表 1 中的值完全相同,则应在工作表 1 中将其删除,并保留工作表 2 中的数据。

我试过这个 tutorial在谷歌网站上,但我仍然无法比较两张纸并删除重复数据。

非常感谢。任何帮助/想法/建议将不胜感激。 :)

+++++++++

我现在刚想出一个代码并使用了二维数组库。

function deleteRowInSheet1() { 
var s1 = SpreadsheetApp.openById("COPY SPREADSHEET ID HERE").getSheetByName('Sheet1');
var s2 = SpreadsheetApp.openById("COPY SPREADSHEET ID HERE").getSheetByName('Sheet2');
var values1 = s1.getDataRange().getValues();
var values2 = s2.getDataRange().getValues();
// Check if Mike exists in SS1.
if (ArrayLib.find(values2, 0, 'Mike') != -1) {
for( var row = values1.length -1; row >= 0; --row ) {
if (values1[row][0] == 'Mike')
s1.deleteRow(parseInt(row)+1);
}
}
}

但是,此代码仅获取特定值,即 Mike。如果工作表 2 中存在行 Mike,则工作表 1 中的行 Mike 也将被删除。我尝试更多地修改代码以比较来自两个不同工作表的两个值,但我似乎无法使其工作。

最佳答案

您使用的 2D 数组库的问题是 find 方法返回一个与其在数组中的位置相对应的整数,在这种情况下这对您来说并不是真正有用的信息。我建议在两个数组中循环(这非常快)并使用 bool 值来确定我们是否保留(或不保留)sheet1 中的值。这是我用于测试的代码,它似乎按预期工作。

function deleteRowInSheet1() { 
var s1 = SpreadsheetApp.openById("1RxtFWZJRWxgW-zUM6S-dvZ0yFe-G2DGJFWI3gAt-1T0").getSheetByName('Sheet1');
var s2 = SpreadsheetApp.openById("1RxtFWZJRWxgW-zUM6S-dvZ0yFe-G2DGJFWI3gAt-1T0").getSheetByName('Sheet2');
var values1 = s1.getDataRange().getValues();
var values2 = s2.getDataRange().getValues();
var resultArray = [];
for(var n in values1){
var keep = true
for(var p in values2){
if( values1[n][0] == values2[p][0] && values1[n][1] == values2[p][1]){
keep=false ; break ;
}
}
if(keep){ resultArray.push(values1[n])};
}
s1.clear()
s1.getRange(1,1,resultArray.length,resultArray[0].length).setValues(resultArray);
}

如您所见,我删除了整个工作表以使用新的数据数组重建它,但这样做我丢失了可能存在的所有格式。如果这对您来说是个问题,那么您将不得不改用 clearContents()See doc here但删除最后一行下方每个未使用行中的任何格式...我想实现起来并不难。

关于javascript - 谷歌脚本 : Delete row if a value in it exists in another sheet,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22008331/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com