Googleスプレッドシート-トリッキーなタスクやサッカーアナライザーの作り方の多目的アシスタントとして

私は夜寝ようとして横になります。そしていつものように千の考え、そしてそれらの中で私はなんとか1つを捕まえることができました。そして、次のように聞こえました。「サッカーの試合のアナライザーを作成してみませんか。ゲームの参加者を入力して、一般的な統計のサンプルと、次の試合で何が期待できるかについての説明を取得するだけです。」確かに、なぜですか?!





次の日、私が目覚めたとき、私が最初にしたことはグーグルでした、なぜなら私たちの世界ではこれはあまりにも平凡な考えであると示唆されたからです(大丈夫!?)。しかし、統計から数字を足したり割ったりするだけでなく、スポーツイベントのさまざまな要素を考慮に入れたかったのですが、それらはたくさんあります。





しかし、グーグルはいつものようにその結果を出しました。私は、パブリックドメインで3〜5kルーブルで販売されているレート計算機やその他の計算テーブルをたくさん見つけました。合計目標の計算を少し覚えていましたが、それらを改善して、出力でスポーツイベントの「マジシャン/ソーサラー/ワンゴー」全体を取得する必要がありました。または、少なくともデータを入力した後に結果を返す数式。





これはパーサーを書いていますか?!

コードを深く掘り下げたくありませんでした。第一に、私はコーダーではなく、仕事の中で常に彼と出会い、彼をかなり理解できる人です。第二に、私はあまりにも怠惰で、簡単な解決策を探していました。そして、Googleスプレッドシートの奇跡は、テーブル、xml、htmlページを解析できることを思い出しました。これは、IMPORTDATA、IMPORTFEED、IMPORTHTML、IMPORTXMLの簡単な数式で実行されます。ここにグーグルの助けへリンクがあります、すべてはそこで詳細に説明されます、私はおそらくこれにこだわるつもりはありません。





, . , , , . fbref.com, 2002 . " , !", - , 3- . , XG, XGa "". API Google Sheets query , sql, , , .





, Google Sheets ?!

, , . , , . , , . . , , Wordpress, , -, , . , , . Inline Google Spreadsheet Viewer. , , :





, Google Sheets?

. , , , . =). , . : , ( , ), , Google Sheets API. .





. " html , Google Apps". 999 , , , .





, , Google Sheets, - . , , . . , , , .





. , , , . , . Google Apps Script .





/******************************************************************************
 * This tutorial is based on the work of Martin Hawksey twitter.com/mhawksey  *
 * But has been simplified and cleaned up to make it more beginner friendly   *
 * All credit still goes to Martin and any issues/complaints/questions to me. *
 ******************************************************************************/

// if you want to store your email server-side (hidden), uncomment the next line
// var TO_ADDRESS = "example@email.net";

// spit out all the keys/values from the form in HTML for email
// uses an array of keys if provided or the object to determine field order
function formatMailBody(obj, order) {
  var result = "";
  if (!order) {
    order = Object.keys(obj);
  }
  
  // loop over all keys in the ordered form data
  for (var idx in order) {
    var key = order[idx];
    result += "<h4 style='text-transform: capitalize; margin-bottom: 0'>" + key + "</h4><div>" + sanitizeInput(obj[key]) + "</div>";
    // for every key, concatenate an `<h4 />`/`<div />` pairing of the key name and its value, 
    // and append it to the `result` string created at the start.
  }
  return result; // once the looping is done, `result` will be one long string to put in the email body
}

// sanitize content from the user - trust no one 
// ref: https://developers.google.com/apps-script/reference/html/html-output#appendUntrusted(String)
function sanitizeInput(rawInput) {
   var placeholder = HtmlService.createHtmlOutput(" ");
   placeholder.appendUntrusted(rawInput);
  
   return placeholder.getContent();
 }

function doPost(e) {

  try {
    Logger.log(e); // the Google Script version of console.log see: Class Logger
    record_data(e);
    
    // shorter name for form data
    var mailData = e.parameters;

    // names and order of form elements (if set)
    var orderParameter = e.parameters.formDataNameOrder;
    var dataOrder;
    if (orderParameter) {
      dataOrder = JSON.parse(orderParameter);
    }
    
    // determine recepient of the email
    // if you have your email uncommented above, it uses that `TO_ADDRESS`
    // otherwise, it defaults to the email provided by the form's data attribute
    var sendEmailTo = (typeof TO_ADDRESS !== "undefined") ? TO_ADDRESS : mailData.formGoogleSendEmail;
    
    // send email if to address is set
    if (sendEmailTo) {
      MailApp.sendEmail({
        to: String(sendEmailTo),
        subject: "Contact form submitted",
        // replyTo: String(mailData.email), // This is optional and reliant on your form actually collecting a field named `email`
        htmlBody: formatMailBody(mailData, dataOrder)
      });
    }

    return ContentService    // return json success results
          .createTextOutput(
            JSON.stringify({"result":"success",
                            "data": JSON.stringify(e.parameters) }))
          .setMimeType(ContentService.MimeType.JSON);
  } catch(error) { // if error return this
    Logger.log(error);
    return ContentService
          .createTextOutput(JSON.stringify({"result":"error", "error": error}))
          .setMimeType(ContentService.MimeType.JSON);
  }
}


/**
 * record_data inserts the data received from the html form submission
 * e is the data received from the POST
 */
function record_data(e) {
  var lock = LockService.getDocumentLock();
  lock.waitLock(30000); // hold off up to 30 sec to avoid concurrent writing
  
  try {
    Logger.log(JSON.stringify(e)); // log the POST data in case we need to debug it
    
    // select the 'responses' sheet by default
    var doc = SpreadsheetApp.getActiveSpreadsheet();
    var sheetName = e.parameters.formGoogleSheetName || "responses";
    var sheet = doc.getSheetByName(sheetName);
    
    var oldHeader = sheet.getRange(1, 1, 1, sheet.getLastColumn()).getValues()[0];
    var newHeader = oldHeader.slice();
    var fieldsFromForm = getDataColumns(e.parameters);
    var row = [new Date()]; // first element in the row should always be a timestamp
    
    // loop through the header columns
    for (var i = 1; i < oldHeader.length; i++) { // start at 1 to avoid Timestamp column
      var field = oldHeader[i];
      var output = getFieldFromData(field, e.parameters);
      row.push(output);
      
      // mark as stored by removing from form fields
      var formIndex = fieldsFromForm.indexOf(field);
      if (formIndex > -1) {
        fieldsFromForm.splice(formIndex, 1);
      }
    }
    
    // set any new fields in our form
    for (var i = 0; i < fieldsFromForm.length; i++) {
      var field = fieldsFromForm[i];
      var output = getFieldFromData(field, e.parameters);
      row.push(output);
      newHeader.push(field);
    }
    
    // more efficient to set values as [][] array than individually
    var nextRow = sheet.getLastRow() + 1; // get next row
    sheet.getRange(nextRow, 1, 1, row.length).setValues([row]);

    // update header row with any new data
    if (newHeader.length > oldHeader.length) {
      sheet.getRange(1, 1, 1, newHeader.length).setValues([newHeader]);
    }
  }
  catch(error) {
    Logger.log(error);
  }
  finally {
    lock.releaseLock();
    return;
  }

}

function getDataColumns(data) {
  return Object.keys(data).filter(function(column) {
    return !(column === 'formDataNameOrder' || column === 'formGoogleSheetName' || column === 'formGoogleSendEmail' || column === 'honeypot');
  });
}

function getFieldFromData(field, data) {
  var values = data[field] || '';
  var output = values.join ? values.join(', ') : values;
  return output;
}
      
      



, , . ?





, , , . .





function update() { 
  var sheetName1 = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Tournament"); 
  var sheetName2 = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("TheMeets"); 
  var sheetName3 = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("TheMeets_sort"); 
  var cellFunction1 = '=IMPORTHTML("https://fbref.com/en/comps/12/La-Liga-Stats","table",1)';
  var cellFunction2 = '=sort({IMPORTHTML("https://fbref.com/en/comps/12/schedule/La-Liga-Scores-and-Fixtures","table",1);IMPORTHTML("https://fbref.com/en/comps/12/3239/schedule/2019-2020-La-Liga-Scores-and-Fixtures","table",1);IMPORTHTML("https://fbref.com/en/comps/12/1886/schedule/2018-2019-La-Liga-Scores-and-Fixtures","table",1);IMPORTHTML("https://fbref.com/en/comps/12/1652/schedule/2017-2018-La-Liga-Scores-and-Fixtures","table",1)},3,FALSE)';
  var cellFunction3 = '=sort(IMPORTHTML("https://fbref.com/en/comps/12/schedule/La-Liga-Scores-and-Fixtures","table",1),3,TRUE)';
  
    sheetName1.getRange('A1').setValue(cellFunction1); 
    sheetName2.getRange('A2').setValue(cellFunction2);
    sheetName3.getRange('A1').setValue(cellFunction3);
}
      
      



. Google Apps Script , . !





!

, :





" " "", , Google Sheets , , . , -.





私の仕事が無駄に行われなかったことを願っています。ロシア語圏では、この記事によって、あなたを内側から誘惑し、食べてしまうアイデアから、さらに2、3人の命を救うことができます。





すべてのコード、手順、およびGoogle AppsScriptを使用してデータをGoogleスプレッドシートに保存する方法はこちらです。





一言で言えば、私はsports.ruに、計算で考慮に入れる予定の内容とカウント方法を書きました








All Articles