Кнопка загрузки файла - PullRequest
0 голосов
/ 19 июня 2019

Я хотел бы иметь простую кнопку в моей электронной таблице Google, которая будет загружать выбранный файл в определенную папку на Google Диске. Без применения гугл форм. Всего одна кнопка загрузки. У кого-нибудь есть пример кода скрипта для этой задачи?

1 Ответ

0 голосов
/ 19 июня 2019

Я понимаю, что вы хотите, чтобы кнопка в вашей таблице SpreadSheet загружала файл с вашего ПК на ваш Google Drive. Первый шаг - создать скрипт загрузки. Вы можете использовать образец из документации по Google Drive API:

function insertFile(fileData, callback) {
  const boundary = '-------314159265358979323846';
  const delimiter = "\r\n--" + boundary + "\r\n";
  const close_delim = "\r\n--" + boundary + "--";

  var reader = new FileReader();
  reader.readAsBinaryString(fileData);
  reader.onload = function(e) {
    var contentType = fileData.type || 'application/octet-stream';
    var metadata = {
      'title': fileData.fileName,
      'mimeType': contentType
    };

    var base64Data = btoa(reader.result);
    var multipartRequestBody =
        delimiter +
        'Content-Type: application/json\r\n\r\n' +
        JSON.stringify(metadata) +
        delimiter +
        'Content-Type: ' + contentType + '\r\n' +
        'Content-Transfer-Encoding: base64\r\n' +
        '\r\n' +
        base64Data +
        close_delim;

    var request = gapi.client.request({
        'path': 'your path file',
        'method': 'POST',
        'params': {'uploadType': 'multipart'},
        'headers': {
          'Content-Type': 'multipart/mixed; boundary="' + boundary + '"'
        },
        'body': multipartRequestBody});
    if (!callback) {
      callback = function(file) {
        console.log(file)
      };   }    request.execute(callback);  }}

Затем вы должны создать кнопку на вашем листе. Для этого перейдите в меню «Вставка»> «Рисование» (или изображение, если оно у вас есть) и нарисуйте собственную кнопку. Как только вы закончите, щелкните правой кнопкой мыши на кнопке и выберите «Назначить сценарий», и напишите имя вашего сохраненного сценария.

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