Umieść = przed skokiem tekstu

Nov 15 2020

Witam Zrobiłem ten skrypt, aby wyeksportować dane z kolumny do pliku .txt na moim dysku Google

function maquinasBonusHunt() {
  var ss = SpreadsheetApp.getActive();
  var sheet = ss.getActiveSheet();
  var range = sheet.getRange('G3:G' + sheet.getLastRow());
  var rows = range.getValues().filter(([g]) => g.toString() != "");
  var fileName="maquinas.txt";
  var folderName="Videos";
  var data = rows.splice(0);
  var str = data.map(function(e) {return e.join()}).join("\n");
  var separador = [" - ", " = "];
  var content = str;

  // get list of folders with matching name
  var folderList = DriveApp.getFoldersByName(folderName);  
  if (folderList.hasNext()) {
    // found matching folder
    var folder = folderList.next();

    // search for files with matching name
    var fileList = folder.getFilesByName(fileName);

    if (fileList.hasNext()) {
      // found matching file - append text
      var file = fileList.next();
      var combinedContent = content;
      file.setContent(combinedContent);
    }
    else {
      // file not found - create new
      folder.createFile(fileName, content);
    }
  }
}

Wszystko jest w porządku, ale muszę wstawić „=”, zanim przeskoczą do innego tekstu, takiego jak y pokazane na zrzucie ekranu. https://i.stack.imgur.com/xvXDA.png

Odpowiedzi

1 Tanaike Nov 15 2020 at 13:18

Wierzę, że twój cel jest następujący.

  • Chcesz dodać =do ostatniego znaku w każdym wierszu.

Aby osiągnąć cel, proponuję następującą modyfikację.

Wzór 1:

W tym wzorcu =jest dodawany, gdy joinjest uruchomiony.

Od:

var str = data.map(function(e) {return e.join()}).join("\n");

Do:

var str = data.map(function(e) {return e.join()}).join("=\n") + "=";

Wzór 2:

W tym wzorze =dodaje się po filterużyciu.

Od:

var rows = range.getValues().filter(([g]) => g.toString() != "");

Do:

var rows = range.getValues().filter(([g]) => g.toString() != "").map(([v]) => [v + "="]);

Bibliografia:

  • Przystąp()
  • filtr()
  • mapa()