Duplikasi File Template Kuisioner dengan Apps Script

Suatu waktu, penulis mendapat tugas untuk membuat kuisioner beberapa karyawan menggunakan Google Spreadsheet.

Di mana daftar karyawan juga telah disediakan pada file Spreadsheet lain seperti ditunjukkan pada gambar di bawah ini:


Skema kerjanya, pertama penulis membuat template kuisioner. Kedua, penulis menduplikasinya, dengan nama file sesuai inisial masing-masing karyawan. Dan terakhir, ketiga, penulis mengumpulkan url tiap file kuisioner tiap karyawan, untuk rekapitulasi.

Kode Apps Script untuk langkah kedua, adalah sebagai berikut:
function duplicateFileAsList() 
{
  var ss = SpreadsheetApp.openById("idsheetinisialkaryawan");//sheet target untuk
  var so=ss.getSheetByName("Dosen");
  var data=so.getRange("A2:D").getValues().map(function(row,index){
    if(row[0]!=""){
      row.push(index);
    }
    return (row[0]!="")?row:null}).filter(function(cellData){return cellData != null;});

  var filesource=DriveApp.getFileById("idspreadsheetkuisioner");
  var folder=DriveApp.getFolderById("idfoldertempatmenyimpanfile");
  for(var i=0;i<data.length;i++){
    filesource.makeCopy(data[i][0],folder);
    console.log(data[i][0]);
  }
}
Sedangkan untuk langkah ketiga, seperti di bawah ini:
function getUrlofFilesinFolder()
{
  var ss = SpreadsheetApp.openById("idspreadshetmenyimpanurl");//sheet target untuk
  var so=ss.getSheetByName("Source");

  var hasil=[],n=0;
  var folder = DriveApp.getFolderById("idfoderfilbersangkutan"); 
  var files = folder.getFiles();
  while (files.hasNext()){
    var file = files.next();
    var name=file.getName();
    var url=file.getUrl();
    hasil[n]=[name,url];
    n++;
    console.log(file.getName());
  }
  so.getRange(2,1,hasil.length,2).setValues(hasil);
}
Tampilan hasil duplikasinya, kurang lebih dapat dilihat gambar sebagaimana berikut:


Sedangkan untuk tahap rekapitulasi, mungkin akan penulis posting pada tulisan berikutnya.

Sebenarnya, langkah ketiga dapat dijadikan satu dengan langkah kedua. Namun saat penulis mengerjakan pekerjaan ini, karena kuisionernya masih dirancang sambil berjalan, penulis lebih memilih untuk melihat datanya terlebih dahulu, baru direkapitulasi.

Komentar



Postingan populer dari blog ini

Kumpulan Source Code Greenfoot

Algorithma Coretan Abstrak dengan HTML5 Canvas

Game TicTacToe dengan Greenfoot

Cara Membuat Halaman HTML Sederhana

Kode Greenfoot Game Snake Sederhana

Honeycomb Style Wallpaper dengan HTML5 Canvas

Ganti Kartu ATM BNI yang Rusak

Tips Agar Website Anda Segera di Terima oleh Google Adsense dan di-Monetize

Selamatan Latar Glundengan Bubuk Banyuwangi

Menggunakan JSON di Netbeans 8.2