Изменить код - конвертировать файл в CSV. Google Apps Script / Google листы - PullRequest
0 голосов
/ 03 марта 2020

Приведенный ниже код работает так, как задумано - за исключением того, что он ТОЛЬКО копирует первые 3 столбца - и мне нужно, чтобы он скопировал все данные в электронной таблице. Я подумал, когда код говорит sheet.getDataRange (); это означает, что все данные, но не в этом случае. Могу ли я получить краткое объяснение проблемы, а не просто ответ - любите знать, почему выбираются только 3 столбца.

function STCSV() {
var ss = SpreadsheetApp.openById("");
var sheets = ss.getSheets();
var sheet = sheets[3];
var formattedDate = Utilities.formatDate(new Date(), "GMT+10", "dd-MM-yyyy' '");
// append ".csv" extension to the sheet name
fileName = formattedDate + SpreadsheetApp.getActiveSpreadsheet().getName() + " ST CSV IMPORT "  + 
".csv";

var folder = DriveApp.getFolderById("");

// convert all available sheet data to csv format
var csvFile = convertRangeToCsvFile_(fileName, sheet);

// create a file in the Docs List with the given name and the csv data
var file = folder.createFile(fileName, csvFile);
}

function convertRangeToCsvFile_(csvFileName, sheet) {
// get available data range in the spreadsheet
var activeRange = sheet.getDataRange();
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(",") + "\r\n";
  }
  else {
    csv += data[row];
  }
}
csvFile = csv;
}
return csvFile;
}

Цените любую помощь. Спасибо

1 Ответ

1 голос
/ 04 марта 2020

Метод getDataRange() возвращает диапазон, соответствующий измерениям, в которых присутствуют данные; следовательно, sheet.getDataRange() возвращает все данные с листа.

Причина, по которой выбраны только 3 столбца, заключается в том, что ваш лист на самом деле имеет только 3 столбца.

Ссылка

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