
[英]Copy row if value exists in both sheet 1 and sheet 2 and paste it to sheet 3. Google Sheets. Google Apps Script
[英]Compare sheet 1 to sheet 2 and output to sheet 3. Google sheets. JavaScript
以下代码成功地将工作表 2 的 A 列与工作表 1 的 B 列进行比较,任何匹配项都会将整行复制到工作表 3。但是,我需要对此代码进行非常细微的更改,以便将工作表 2 的 A 列与 N 列进行比较表 1 而不是 B 列。有人可以帮我更改此代码吗? 这是上一篇文章的链接, 用于谷歌应用程序脚本的 Java 脚本优化
function copyRowtoSheet3() {
var spreadsheetId = "1Aw11LiKzyezfrTQIuTsJPhUFtz8RPqLCc8FlIiy0ZlE";
var ss = SpreadsheetApp.openById(spreadsheetId);
var s1 = ss.getSheetByName('Sheet1');
var s2 = ss.getSheetByName('Sheet2');
// 1. Retrieve values from "Sheet1" and "Sheet2",
var values1 = s1.getDataRange().getValues();
var values2 = s2.getRange(1, 1, s2.getLastRow(), 1).getValues();
// 2. Create an object using values2.
var obj = values2.reduce((o, [e]) => {
o[e] = null;
return o;
}, {});
// 3. Create resultArray using values1 and obj.
var resultArray = values1.filter(([,b]) => b in obj);
// 4. Put resultArray to Sheet3.
Sheets.Spreadsheets.Values.update({values: resultArray}, spreadsheetId, "Sheet3", {valueInputOption: "USER_ENTERED"});
}
我尝试过的是:
var resultArray = values1.filter(([,n]) => n in obj);
然而这并没有奏效。 有任何想法吗?
var resultArray = values1.filter(([,b]) => b in obj);
被修改。 在您当前的脚本中,比较了[,b]
的列“B”。当您的脚本被修改时,请进行如下修改。
从: var resultArray = values1.filter(([,b]) => b in obj);
到:
var resultArray = values1.filter(b => b[13] in obj);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.