删除 Google 脚本中的文件 .set垃圾'You do not have authorization to perform that action.'



我试图每天从谷歌电子表格创建一个csv文件。出于某种原因,我可以使用。settrashed (True)删除文件,文件将被删除,但我得到一个错误说'你没有授权执行该操作。'

是我的代码。如有任何帮助,不胜感激。

function saveAsCSV() {
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var sheets = ss.getSheets();
  // create a folder from the name of the spreadsheet
  var folder = DocsList.getFolder(ss.getName().toLowerCase().replace(/ /g,'_'));
  for (var i = 0 ; i < sheets.length ; i++) {
    var sheet = sheets[i];
    // append ".csv" extension to the sheet name
    fileName = sheet.getName() + ".csv";
    // convert all available sheet data to csv format
    var csvFile = convertRangeToCsvFile_(fileName, sheet);
    // update a file in the Docs List with the given name and the csv data
    var folder = DocsList.getFolder('fitbitdata_mk3'); 
    folder.createFile(fileName, csvFile);
    deleteDocByName('Sheet1.csv');
    Logger.log('deleted');
    //  folder.createFile(fileName, csvFile);   //i put it before the delete

  }
  Browser.msgBox('UPDATED Files are waiting in a folder named ' + folder.getName());
}

function deleteDocByName(fileName){
  var docs=DocsList.find(fileName)
  for(n=0;n<docs.length;++n){
    if(docs[n].getName() == fileName){
      var ID = docs[n].getId()
      DocsList.getFileById(ID).setTrashed(true)
    }
  }
}


function convertRangeToCsvFile_(csvFileName, sheet) {
  // get available data range in the spreadsheet
  var activeRange = sheet.getDataRange();
  try {
    var data = activeRange.getValues();
    var csvFile = undefined;
    // loop through the data in the range and build a string with the csv data
    if (data.length > 1) {
      var csv = "";
      for (var row = 0; row < data.length; row++) {
        for (var col = 0; col < data[row].length; col++) {
          if (data[row][col].toString().indexOf(",") != -1) {
            data[row][col] = """ + data[row][col] + """;
          }
        }
        // join each row's columns
        // add a carriage return to end of each row, except for the last one
        if (row < data.length-1) {
          csv += data[row].join(",") + "rn";
        }
        else {
          csv += data[row];
        }
      }
      csvFile = csv;
    }
    return csvFile;
  }
  catch(err) {
    Logger.log(err);
    Browser.msgBox(err);
  }
}  

我也遇到了同样的问题。请在问题跟踪器上标记问题。

https://code.google.com/p/google-apps-script-issues/issues/detail?id=4145& colspec =恒星% 20打开% 20 id % 20类型% 20地位% 20总结% 20组件% 20所有者

相关内容

最新更新