Я хотел бы загрузить отдельный лист длиной 10000 строк из Google Sheets, разделенный на 20 отдельных файлов csv с размером пакета 500 строк в каждом. Возможно ли это сделать с помощью Google Sheets?
Мне не удалось найти встроенную поддержку листов для загрузки и разделения файлов на несколько частей/фрагментов. Но мне удалось найти Google Apps Script
код, который сохраняет лист в csv.
Итак, что я сделал, так это изменил код, а затем заставил его превратить лист в несколько CSV.
Суть в том, что все эти файлы будут загружены в папку на диске Google, на котором вы вошли в систему, а затем вы сможете загрузить их в виде zip-файла. (Я покажу это позже ниже)
Вот исходный код.
И вот измененный код, который я сделал:
function saveAsCSV() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var sheet = ss.getActiveSheet();
// Update numFiles into how many files you want is outputted
// The script will calculate how many rows it can place in a file equally
// Excess will be placed into an additional file
var numFiles = 5;
var rowsPerFile = Math.floor(sheet.getDataRange().getLastRow() / numFiles);
// create a folder from the name of the spreadsheet
var folder = DriveApp.createFolder(ss.getName().toLowerCase().replace(/ /g,'_') + '_csv_' + new Date().getTime());
// append ".csv" extension to the sheet name
fileName = sheet.getName();
// convert all available sheet data to csv format
var csvFiles = convertRangeToCsvFile_(sheet, rowsPerFile);
// create a file in the Docs List with the given name and the csv data
csvFiles.forEach(function(csvFile, i){
var csvName = fileName + '_' + (i + 1) + '.csv';
folder.createFile(csvName, csvFile);
});
}
function convertRangeToCsvFile_(sheet, rowsPerFile) {
// get available data range in the spreadsheet
var activeRange = sheet.getDataRange();
try {
var data = activeRange.getValues();
var csvFiles = [];
// 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];
}
if ((row + 1) % rowsPerFile === 0) {
csvFiles.push(csv);
csv = "";
}
}
}
// If there are remainders that doesnt reach the number of files needed.
// It will add another file, containing all remainder rows there.
// 10010 rows / 20 files = 10 rows excess
// 21st file will contain those 10 rows excess
// No excess means no 21st file
if (csv) {
csvFiles.push(csv);
}
return csvFiles;
}
catch(err) {
Logger.log(err);
}
}
Образец данных:
Пример вывода:
Щелкнув правой кнопкой мыши по папке, созданной на Google Диске, вы сможете загрузить всю папку в виде zip-файла, содержащего все CSV-файлы.
Вот загруженный zip-файл, содержащий все файлы csv:
Поскольку имеется 22 строки, а коду примера требуется 5 файлов, был создан 6-й файл, содержащий лишние 2 строки.