【发布时间】:2021-12-03 18:52:50
【问题描述】:
大家好, 我正在处理 Google Sheet 上的数据集,我需要通过 col 3 名称获取随机数据(指定数字)以进行审核我正在使用 google app 脚本,但无法获取数据。这是我尝试过的代码,但我不想要数据的百分比我想要在 col 3 中为每个员工平均分布的随机数据。
function myFunction() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var trn = ss.getSheetByName('Data');
var originalData = trn.getRange(2, 1, trn.getLastRow() - 1, 3).getValues();
var ReviewerEmail = data;
var data = originalData.filter(function(item) {
return item[1] === 'rob' || item[1] === 'john' || item[1] === 'toger';
});
//Logger.log(data);
var targetsheet = ss.insertSheet(Reviewer);
targetsheet.getRange(1, 1, data.length, data[0].length).setValues(data);
}
function getsampledata() {
var sheet = SpreadsheetApp.getActiveSheet();
var range = sheet.getRange('A:C');
var values = range.getValues();
var headers = values.shift();
var nameColumn = 1;
var uniqueNames = values
.map((row) => row[nameColumn])
.filter((item, i, ar) => ar.indexOf(item) === i)
.filter(String);
var data = [headers];
uniqueNames.forEach(function(name) {
var nameEntries = values.filter((row) => row[nameColumn] == name);
var entries = nameEntries.length;
var tenth = Math.round((entries / 100) * 27.35); //Sampling Percentage
for (i = 0; i < tenth; i++) {
var random = Math.floor(Math.random() * nameEntries.length);
data.push(nameEntries[random]);
nameEntries.splice(random, 1);
}
});
return data;
}
【问题讨论】:
-
对不起,我没有完全理解你的目标,尤其是这个
I don't want the % of data I want to get it. I want the equal distributed random data for each employee.。您能否提供一些有关预期输出的示例。并分享样张 -
@Ron M 我想要在 col 3 中为每个员工平均分布的随机数据。就像 john 做了 4 个样本我需要 2 或 3 个(我将指定的数字)它会给出 2 个随机行约翰工作
标签: javascript google-apps-script google-sheets random