Как создать массивы из данных ячейки листа Google? - PullRequest
0 голосов
/ 09 мая 2019

Я пытаюсь создать список (4X1) массивов из данных листа Google.

   A        B    C      D       E     F      G      H      I     J 
Project | Per1 | W1 |  Team1 | Per2 | W2 | Team2 | Per3 | W3 | Team3|
—————————————————————————————————————————————————————————————————————
   p1   | Bill | .5 |  Tech  | Alice|  1 | Other |      |    |      |
   p2   |Larry |  1 |  Tech  | Bill |  1 | Other | Tina | 1  | Other|
   p3   | Joe  |  2 |  Tech  | Beth |  1 | Tech  |      |    |      |
   p4   |Kathy | .5 |  Tech  |      |    |       |      |    |      |
   p5   | Bill | 1  |  Tech  | Larry|  1 | Other |      |    |      |

* Моя репутация не позволяет мне публиковать фотографии

Пока я могу создать список (3x1) массивов.

 function arrayOfObjects() {
  var ss=SpreadsheetApp.getActive();
  var sh=ss.getSheetByName('Sheet1');
  var vA=sh.getRange("B2:D6").getValues();
  Logger.log(vA);
}

Пока мои результаты:

 [[Bill, 0.5, Tech], [Larry, 1.0, Other], [Joe, 2.0, Tech], [Kathy, 0.5, Other], [Alice, 1.0, Tech]]

Но это относится только к диапазону B2: D6

Мне нужно иметь возможность связывать имена с проектами (p1, p2 ... для дальнейшего анализа) Я хотел бы, чтобы результаты были (4X1) массивов:

[[p1,Bill,.5,Tech], [p1,Alice,1,Other],[p2,Larry,1,Other],[p2,Bill,.5,Other],
[p2,Tina,1,Other]........[p5,Larry,1,Other]]

Где в конце концов я хочу таблицу:

    A           B                         
| Name | Number Of project|  
———————————————————————————
| Bill |        3         |
|Larry |        2         |
| Joe  |        1         |   
|Kathy |        1         |
| Alice|        1         |
   etc...

Ответы [ 2 ]

0 голосов
/ 09 мая 2019

1x4 Массивы и объекты

Это также приведет к созданию массивов 1x4 и объектов. Выбирай.

function projectInfo() {
  var ss=SpreadsheetApp.getActive();
  var sh=ss.getSheetByName('Projects');
  var rg=sh.getDataRange();
  var vA=rg.getValues();
  var projA=[];
  var projB=[];
  for(var i=1;i<vA.length;i++) {
    for(var j=1;j<vA[i].length;j+=3) {
      if(vA[i][j] && vA[i][j+1] && vA[i][j+2]) {
        projA.push([vA[i][0],vA[i][j],vA[i][j+1],vA[i][j+2]]);
        projB.push({project:vA[i][0],person:vA[i][j],weight:vA[i][j+1],team:vA[i][j+2]}); 
      }
    }
  }
  var rObj={array:projA,object:projB};
  return rObj;
}

Эта версия отображает их в небольшом диалоговом окне и показывает, как вы можете ссылаться на них как на индексы, так и по имени (ключу).

function projectInfo() {
  var ss=SpreadsheetApp.getActive();
  var sh=ss.getSheetByName('Projects');
  var rg=sh.getDataRange();
  var vA=rg.getValues();
  var projA=[];
  var projB=[];
  for(var i=1;i<vA.length;i++) {
    for(var j=1;j<vA[i].length;j+=3) {
      if(vA[i][j] && vA[i][j+1] && vA[i][j+2]) {
        projA.push([vA[i][0],vA[i][j],vA[i][j+1],vA[i][j+2]]);
        projB.push({project:vA[i][0],person:vA[i][j],weight:vA[i][j+1],team:vA[i][j+2]}); 
      }
    }
  }
  var rObj={array:projA,object:projB};
  var html='<style>td,th{border:1px solid black;text-align:center;}</style><table>';
  html+='<tr><th>Project</th><th>Person</th><th>Weight</th><th>Team</th></tr>';
  html+='<tr><td colspan="4">Array(indices)</tr>';
  for(var i=0;i<projA.length;i++) {
    html+=Utilities.formatString('<tr><td>%s</td><td>%s</td><td>%s</td><td>%s</td>',projA[i][0],projA[i][1],projA[i][2],projA[i][3]);
  }
  html+='<tr><td colspan="4">Object(key,value)</tr>';
  for(var i=0;i<projB.length;i++) {
    html+=Utilities.formatString('<tr><td>%s</td><td>%s</td><td>%s</td><td>%s</td>',projB[i].project,projB[i].person,projB[i].weight,projB[i].team);
  }
  html+='</table>';
  var userInterface=HtmlService.createHtmlOutput(html);
  SpreadsheetApp.getUi().showModelessDialog(userInterface, 'Array on Top and Object on Bottom')
}
0 голосов
/ 09 мая 2019

То есть вам нужно идти ряд за строкой и делать записи для каждого человека в команде?

data = vA; 
for (var i=0; i<data.length;i++)
    {
    var project = data[i][0];
    if (data[i][1]!="")push([project,data[i][1],data[i][2],data[i][3] ]);//first person
    if (data[i][4]!="")push([project,data[i][4],data[i][5],data[i][6] ]);//second person
    if (data[i][7]!="")push([project,data[i][7],data[i][8],data[i][9] ]);//third person
    }//for loop

Возможно, есть более элегантный способ сделать это, но это то, что я бы сделал в первую очередь.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...