繁体   English   中英

想要在3张纸上自动分类时将其锁定

[英]Wanting auto sort on 3 sheets, when one is locked

请参阅有关此问题的上一篇文章; 自动排序不适用于一个Google表格中的多个表格

这是上一期的好脚本;

function onEdit(event){
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var sheet = event.source.getActiveSheet().getName()
  var editedCell = event.range.getSheet().getActiveCell();
if(sheet=="Loan Inquiries"){
  var columnToSortBy = 2;
  var tableRange = "A3:G99"; //range to be sorted
  if(editedCell.getColumn() == columnToSortBy){   
    var range = ss.getActiveSheet().getRange(tableRange); 
    range.sort( { column : columnToSortBy, ascending: true } );
  }}
  else if(sheet=="Deals in Escrow"){
    var columnToSortBy = 7;
  var tableRange = "A3:I99"; //range to be sorted
  if(editedCell.getColumn() == columnToSortBy){   
     var tableRange = "A3:I99"; //range to be sorted
     var range = ss.getActiveSheet().getRange(tableRange); 
    range.sort( { column : columnToSortBy, ascending: true } );
  }
  else{return}
}}

function test_onEdit() {
  onEdit({
    user : Session.getActiveUser().getEmail(),
    source : SpreadsheetApp.getActiveSpreadsheet(),
    range : SpreadsheetApp.getActiveSpreadsheet().getActiveCell(),
    value : SpreadsheetApp.getActiveSpreadsheet().getActiveCell().getValue(),
    authMode : "LIMITED"
  });
}

这个线程成功地解决了我的问题,但是,现在我要做的是对第三张表进行自动排序,该表被锁定到其他人,而不是我自己。 第三张纸的标题为“ 2017年Karlan生产”。 我还希望该第三张工作表从第二张工作表“托管中的交易”中提取所有新数据,并采用与第二张工作表相同的格式,并在将数据导入到第三张工作表中时自动排序,但我也可以在第3张表格中也手动输入新交易,并且仍然能够自动更新。

我相信这将满足您的要求:

function onEdit(event){
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var sheet = event.source.getActiveSheet().getName()
  var editedCell = event.range.getSheet().getActiveCell();
if(sheet=="Loan Inquiries"){
  var columnToSortBy = 2;
  var tableRange = "A3:G99"; //range to be sorted
  if(editedCell.getColumn() == columnToSortBy){   
    var range = ss.getActiveSheet().getRange(tableRange); 
    range.sort( { column : columnToSortBy, ascending: true } );
  }}
  else if(sheet=="Deals in Escrow"){
    var columnToSortBy = 7;
    var tableRange = "A3:I99"; //range to be sorted
  if(editedCell.getColumn() == columnToSortBy){   
    var range = ss.getActiveSheet().getRange(tableRange); 
    range.sort( { column : columnToSortBy, ascending: true } );
    combineData()
  }}
   else if(sheet=="Karlan Production for 2017"){
     var columnToSortBy = 7;
     if(editedCell.getColumn() == columnToSortBy){ 
  combineData()
   }}
  else{return}
}

function combineData(){
var ss = SpreadsheetApp.getActiveSpreadsheet();
var s=ss.getSheets()[1]
var lr = s.getLastRow()
var s1=ss.getSheets()[2]
var lr1 = s1.getLastRow()
var lc1=s1.getLastColumn() //get the last column of 'Karlan Production for 2017' 
var rng=s.getRange(3, 1, lr,lc1).getValues() //get 'Deals in Escrow' values
var rng1=s1.getRange(3, 1, lr1,lc1).getValues() //get 'Karlan Production for 2017' values
var rng2=[]
var rng2=rng.concat(rng1) //combine 'Deals in Escrow' and 'Karlan Production   for 2017' values (all rows)
removeDuplicates(rng2) // call remove duplicates sending combined array  
}

function removeDuplicates(data) {
  var ss = SpreadsheetApp.getActiveSpreadsheet()
  var s1=ss.getSheets()[2]
  var newData = new Array();
  for(i in data){
    var row = data[i];
    var duplicate = false;
    for(j in newData){
      if(row.join() == newData[j].join()){
        duplicate = true;
      }
    }
    if(!duplicate){
      newData.push(row);//create array of non duplicate rows
    }
  }
  s1.clearContents(); //clear 'Karlan Production for 2017'
  var sor=s1.getRange(3, 1, newData.length,     newData[0].length).setValues(newData); //set new array
  sor.sort( { column : 7, ascending: true } );//sort new data
}

添加新工作表后,单击工作表选项卡上的箭头。 单击保护表。 在弹出窗口中,输入描述,然后单击工作表按钮。 单击设置权限按钮。 在范围编辑权限弹出窗口中,单击“只有您”旁边的箭头。 选择“自定义”,然后添加您希望能够编辑表格的其他人的电子邮件地址。 单击完成。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM