使用Gmail应用程序脚本按月分组标签计数

Google应用程序新手脚本/Java脚本。

我正在尝试按月对以下代码的结果进行分组,以便将数据用作图表元素,执行此操作的最佳方法是什么:

function listLabels(labelcount) {
  var response = Gmail.Users.Labels.list('me');
  if (response.labels.length == 0) {
    Logger.log('No labels found.');
  } else {
    Logger.log('Labels:');
    for (var i = 0; i < response.labels.length; i++) {
      var label = response.labels[i];

      // Use the label name to get the messages that match this label
      var label_messages = Gmail.Users.Messages.list('me', {
        'labelIds': [label.id]
      });

      Logger.log('%s = %s', label.name, label_messages.resultSizeEstimate);
    }
  }
}

解决方案

各月标签分布

此函数收集每个标签每月和所有月份的具有给定标签的消息数量,而不考虑年份。不过,您可以轻松地对其进行修改,以过滤掉不需要的年份。

在每次运行时清除数据后,它会将数据转储到活动电子表格中。为方便起见,我将数据放入每月数组中,并使用Join()方法显示它们。如果您希望展开这些数据,您可以通过拆分列来轻松地完成此操作,并且我在其上方包含了一个列,其中包含相应月份的第一个字母。

function listLabels() {
  var ss=SpreadsheetApp.getActive();
  var sh=ss.getActiveSheet();
  var response = Gmail.Users.Labels.list('me');
  var msA=['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec']
  var miA=['J','F','M','A','M','J','J','A','S','O','N','D']
  var mA=[0,0,0,0,0,0,0,0,0,0,0,0];
  if (response.labels.length) {
    sh.clearContents();
    sh.appendRow(['Label Name','Monthly Distribution'])
    sh.appendRow(['',miA.join(',')])
    for (var i = 0; i < response.labels.length; i++) {
      var label=response.labels[i];
      var label_messages = Gmail.Users.Messages.list('me', {'labelIds': [label.id]});
      var msgs=label_messages.messages;
      if(msgs) {
        var lA=[0,0,0,0,0,0,0,0,0,0,0,0];
        for(var j=0;j<msgs.length;j++) {
          var m=GmailApp.getMessageById(msgs[j].id).getDate().getMonth();
          mA[m]+=1;
          lA[m]+=1;
        }
        sh.appendRow([label.name,lA.join(',')])
      }
    }
    sh.appendRow(['***********************']);
    sh.appendRow(['***********************']);
    sh.appendRow(['Month','Total Count']);
    for(var i=0;i<12;i++) {
      sh.appendRow([msA[i],mA[i]]);
    }
  }
}

这是输出的样子。

我截断了各个标签,因为我不想共享我的私人信息。

  • Gmail API
  • Class GmailApp

标签在年和月中的分布

function listLabelsIncludingYears() {
  var ss=SpreadsheetApp.getActive();
  var sh=ss.getActiveSheet();
  var response = Gmail.Users.Labels.list('me');
  var msA=['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec']
  var miA=['J','F','M','A','M','J','J','A','S','O','N','D']
  var mA=[0,0,0,0,0,0,0,0,0,0,0,0];
  var yObj={yA:[]};
  if (response.labels.length) {
    sh.clearContents();
    sh.appendRow(['Label Name','Year','Monthly Distribution'])
    sh.appendRow(['','',miA.join(',')])
    for (var i = 0; i < response.labels.length; i++) {
      var label=response.labels[i];
      var label_messages = Gmail.Users.Messages.list('me', {'labelIds': [label.id]});
      var msgs=label_messages.messages;
      if(msgs) {
        var lA=[0,0,0,0,0,0,0,0,0,0,0,0];
        for(var j=0;j<msgs.length;j++) {
          var m=GmailApp.getMessageById(msgs[j].id).getDate().getMonth();
          var y=GmailApp.getMessageById(msgs[j].id).getDate().getFullYear();
          if(yObj.hasOwnProperty(y)) {
            yObj[y][m]+=1;
          }else{
            yObj[y]=[0,0,0,0,0,0,0,0,0,0,0,0,0];
            yObj.yA.push(y);
            yObj[y][m]+=1;
          }
          lA[m]+=1;
        }
        sh.appendRow([label.name,y,lA.join(',')]);
      }
    }
    SpreadsheetApp.flush();
    sh.getRange(3,1,sh.getLastRow()-2,sh.getLastColumn()).sort({column:2,ascending:true});
    sh.getRange(2,3,sh.getLastRow()-1,1).splitTextToColumns(',');
    sh.autoResizeColumns(1,sh.getLastColumn())
    SpreadsheetApp.flush();
    sh.appendRow(['***********************']);
    sh.appendRow(['***********************']);
    sh.appendRow(['Year','Month','Total Count']);
    yObj.yA.sort();
    for(var k=0;k<yObj.yA.length;k++) {
      for(var i=0;i<12;i++) {
        sh.appendRow([yObj.yA[k],msA[i],yObj[y][i]]);
      }
    }
  }
}

我还添加了自动排序、将文本拆分到列和调整大小。

添加了页面令牌支持

我应其他用户的请求添加了页面令牌支持。

function listLabelsIncludingYears() {
  var ss=SpreadsheetApp.getActive();
  var sh=ss.getActiveSheet();
  var response = Gmail.Users.Labels.list('me');
  var msA=['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec']
  var miA=['J','F','M','A','M','J','J','A','S','O','N','D']
  var mA=[0,0,0,0,0,0,0,0,0,0,0,0];
  var yObj={yA:[]};
  if (response.labels.length) {
    sh.clearContents();
    sh.appendRow(['Label Name','Year','Monthly Distribution'])
    sh.appendRow(['','',miA.join(',')])
    for (var i = 0; i < response.labels.length; i++) {
      var label=response.labels[i];
      var label_messages = Gmail.Users.Messages.list('me', {'labelIds': [label.id]});
      var pagetoken='';
      do{
        var msgs=label_messages.messages;
        if(msgs) {
          var lA=[0,0,0,0,0,0,0,0,0,0,0,0];
          for(var j=0;j<msgs.length;j++) {
            var m=GmailApp.getMessageById(msgs[j].id).getDate().getMonth();
            var y=GmailApp.getMessageById(msgs[j].id).getDate().getFullYear();
            if(yObj.hasOwnProperty(y)) {
              yObj[y][m]+=1;
            }else{
              yObj[y]=[0,0,0,0,0,0,0,0,0,0,0,0,0];
              yObj.yA.push(y);
              yObj[y][m]+=1;
            }
            lA[m]+=1;
          }
          sh.appendRow([label.name,y,lA.join(',')]);
        }
        pagetoken=label_messages.nextPageToken;  
      }while(pagetoken!='');
    }
    SpreadsheetApp.flush();
    sh.getRange(3,1,sh.getLastRow()-2,sh.getLastColumn()).sort({column:2,ascending:true});
    sh.getRange(2,3,sh.getLastRow()-1,1).splitTextToColumns(',');
    sh.autoResizeColumns(1,sh.getLastColumn())
    SpreadsheetApp.flush();
    sh.appendRow(['***********************']);
    sh.appendRow(['***********************']);
    sh.appendRow(['Year','Month','Total Count']);
    yObj.yA.sort();
    for(var k=0;k<yObj.yA.length;k++) {
      for(var i=0;i<12;i++) {
        sh.appendRow([yObj.yA[k],msA[i],yObj[y][i]]);
      }
    }
  }
}

注意:尚未测试页面令牌支持,因为我删除了大部分电子邮件,因此永远不会触发需要。

相关文章