将两个脚本合并到一个Google工作表中

时间:2017-06-08 17:21:25

标签: google-apps-script

我正在制作电子表格以便工作,我需要使用两个脚本,但是当我转到“脚本编辑器”时我只能使用一个。我不知道如何合并这两个脚本,以便它们在编辑单元格时同时起作用。非常感谢您的帮助!这两个脚本如下。

****第一个****

/**
 * Automatically sorts the 1st column (not the header row) Ascending.
 */
function onEdit(event){
  var sheet = event.source.getActiveSheet();
  var editedCell = sheet.getActiveCell();

  var columnToSortBy = 4;
  var tableRange = "A2:T99"; // What to sort.

  if(editedCell.getColumn() == columnToSortBy){   
    var range = sheet.getRange(tableRange);
    range.sort( { column : columnToSortBy, ascending: false } );
  }
}

****第二个:*****

function onEdit(event)
{ 
  var timezone = "UTC-5";
  var timestamp_format = "mm-dd-yyyy'Time:' hh:mm:ss";
  var updateColName = "Parent Sign-Out";
  var timeStampColName = "Timestampt";
  var sheet = event.source.getSheetByName('Sheet1, Sheet2'); //Name of the sheet where you want to run this script.


  var actRng = event.source.getActiveRange();
  var editColumn = actRng.getColumn();
  var index = actRng.getRowIndex();
  var headers = sheet.getRange(1, 1, 1, sheet.getLastColumn()).getValues();
  var dateCol = headers[0].indexOf(timeStampColName);
  var updateCol = headers[0].indexOf(updateColName); updateCol = updateCol+1;
  if (dateCol > -1 && index > 1 && editColumn == updateCol) { // only timestamp if 'Last Updated' header exists, but not in the header row itself!
    var cell = sheet.getRange(index, dateCol + 1);
    var date = Utilities.formatDate(new Date(), timezone, timestamp_format);
    cell.setValue(date);
  }
}

}

1 个答案:

答案 0 :(得分:0)

你可以按照你的要求组合它们:



int a=0,o=0,i=0,e=0,u=0;
for (int ii = 0;ii<s1.length();ii++)
{
    if (s1.charAt(ii)=='a')a++;
    if (s1.charAt(ii)=='o')o++;
    if (s1.charAt(ii)=='i')i++;
    if (s1.charAt(ii)=='u')u++;
    if (s1.charAt(ii)=='e')e++;
}
for (int ii = 0;ii<s2.length();ii++)
{
    if (s2.charAt(ii)=='a')a++;
    if (s2.charAt(ii)=='o')o++;
    if (s2.charAt(ii)=='i')i++;
    if (s2.charAt(ii)=='u')u++;
    if (s2.charAt(ii)=='e')e++;
}
int total = a+o+i+u+e;
System.out.println (total);
&#13;
&#13;
&#13;

或者你可以从onedit函数调用第二个函数:

&#13;
&#13;
/**
 * Automatically sorts the 1st column (not the header row) Ascending.
 */
function onEdit(event){
  var sheet = event.source.getActiveSheet();
  var editedCell = sheet.getActiveCell();

  var columnToSortBy = 4;
  var tableRange = "A2:T99"; // What to sort.

  if(editedCell.getColumn() == columnToSortBy){   
    var range = sheet.getRange(tableRange);
    range.sort( { column : columnToSortBy, ascending: false } );
  }
  // 2nd script
   var timezone = "UTC-5";
  var timestamp_format = "mm-dd-yyyy'Time:' hh:mm:ss";
  var updateColName = "Parent Sign-Out";
  var timeStampColName = "Timestampt";
  var sheet = event.source.getSheetByName('Sheet1, Sheet2'); //Name of the sheet where you want to run this script.


  var actRng = event.source.getActiveRange();
  var editColumn = actRng.getColumn();
  var index = actRng.getRowIndex();
  var headers = sheet.getRange(1, 1, 1, sheet.getLastColumn()).getValues();
  var dateCol = headers[0].indexOf(timeStampColName);
  var updateCol = headers[0].indexOf(updateColName); updateCol = updateCol+1;
  if (dateCol > -1 && index > 1 && editColumn == updateCol) { // only timestamp if 'Last Updated' header exists, but not in the header row itself!
    var cell = sheet.getRange(index, dateCol + 1);
    var date = Utilities.formatDate(new Date(), timezone, timestamp_format);
    cell.setValue(date);
  }
}
  
}
&#13;
&#13;
&#13;