【问题标题】:Javascript to get the Random sample of dataJavascript 获取随机数据样本
【发布时间】: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


【解决方案1】:

如果您想要特定数量的样本,请使用参数来指示您想要每个样本的数量。

整个工作脚本:

function getsampledata(sample) {
  var sheet = SpreadsheetApp.getActiveSheet();
  var range = sheet.getRange('A:C');
  var values = range.getValues();
  var headers = values.shift();
  var nameColumn = 2;
  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);
    for (i = 0; i < sample; i++) {
      var random = Math.floor(Math.random() * nameEntries.length);
      data.push(nameEntries[random]);
      nameEntries.splice(random, 1);
    }
  });
  return data;
}

【讨论】:

  • 感谢您的帮助,但如果我不想要数据的采样百分比怎么办。相反,我想要每个员工数据的 2 或 3 行。
  • 您有具体的百分比吗?或具体计数?如果我们有 100 件物品,50 件来自 rob,30 件来自 john,20 件来自 toger,你希望每个人拥有多少件物品? @5aadat
  • 您需要具体分配规则以便其他人可以理解@5aadat
  • 不是任何具体的,例如,我想要每个数据的 4 行数据,并且每天都可以改变不是任何百分比,而是像 john 这样的数字做了 350 行工作,我需要 4 个随机样本 @ASyntuBU
  • 更多澄清 - 就像每个人都做了 300,400,500 行工作,我想要每个指定数量的样本。就像我想要每个 @ASyntuBU 的 4 个随机样本
猜你喜欢
  • 1970-01-01
  • 2017-02-21
  • 2017-05-11
  • 2017-09-03
  • 2017-05-13
  • 1970-01-01
  • 1970-01-01
  • 2021-03-05
  • 2023-02-23
相关资源
最近更新 更多