使用Apps脚本从Gmail中的标签导出电子邮件地址

时间:2014-09-02 12:09:11

标签: email google-apps-script

嗨,我试图从Gmail中的标签发送者发送Emailadresses,名为" Suarez"。但它只是运行而且从未完成,应该是大约372封电子邮件。是否可以打印到记录器?

以下是我的尝试:

function getEmailsadresses(){

var threads = GmailApp.search("in:suarez");

for (var i = 0; i < threads.length; i++) {

  var messages = threads[i].getMessages();

  for (var m = 0; m < messages.length; m++) {
    var msg = messages[m].getFrom();
  }
}

    Logger.log(msg()); // log from address of the message

}

1 个答案:

答案 0 :(得分:0)

我使用嵌入在电子表格中的脚本来读取Label中每个线程中的每条消息,这可能是一个很好的起点。

我的具体用例是每次发送或接收短信时记录我的Android手机发送给我的短信息。

所以只需更改标签名称就可以使用它,也可以删除我在消息上添加的数据过滤。由于我有大量数据,因此我设置了一个时间触发任务管理器,以便在小数据集中工作以避免超出时间限制。

用法很简单:运行“startSMSLog”并继续喝几杯咖啡,直到电子表格中的单元格A1停止为红色......就是这样。

以下代码:启动功能

function startSMSLog(){
  var triggerID = ScriptApp.newTrigger('countSMSLogEmails').timeBased().everyMinutes(5).create().getUniqueId();
  var thisTrigger = PropertiesService.getScriptProperties().setProperty('thisTriggerSMS',triggerID);
  PropertiesService.getScriptProperties().setProperty('current thread SMS',0);
  var sh = SpreadsheetApp.getActive().getSheetByName('SMS'); // change to the name of your sheet
  sh.getRange('A1').setBackground('red');
  countSMSLogEmails(true);
}

和“工作”代码:

function countSMSLogEmails(clearSheet){
  var sh = SpreadsheetApp.getActive().getSheetByName('SMS');
  var start = Number(PropertiesService.getScriptProperties().getProperty('current thread SMS'));
  var CallLogThreads = GmailApp.getUserLabelByName('SMS').getThreads(start,10);
  if(CallLogThreads.length==0){
    sh.sort(2,false);
    sh.getRange('A1').setBackground('#FFC');
    var triggers = ScriptApp.getProjectTriggers();
    var thisTrigger = PropertiesService.getScriptProperties().getProperty('thisTriggerSMS');
    for(var n in triggers){
      if(triggers[n].getUniqueId()==thisTrigger){ScriptApp.deleteTrigger(triggers[n])};
    }
    sh.getRange('A1').setValue('Subject  (Log on '+Utilities.formatDate(new Date(), Session.getScriptTimeZone(), "dd-MMM-yy  HH:mm")+')');
    return;
  } else {
    PropertiesService.getScriptProperties().setProperty('current thread SMS',start+CallLogThreads.length);
  }
  var data = [];
  for(var n=0;n<CallLogThreads.length;n++){ 
    var thread = CallLogThreads[n];
    Logger.log('thread message count = '+thread.getMessageCount());
    var msg = thread.getMessages();
    var msgData = [];
    for(var m in msg){
      var msgDate = msg[m].getDate();
      var msgSubject = msg[m].getSubject(); 
      var msgBody = msg[m].getBody().replace(/[\n\r]/g,' ').replace(/&#39;/g,"'").replace(/&nbsp;/g,"!").replace(/&amp;/g,"&").replace(/&quot;/g,'"')
      .replace(/&gt;/g,'>').replace(/&lt;/g,'<').replace(/<br \/>/g,'\n').replace(/<br>/g,'\n');
      msgData.push([msgSubject,msgDate,msgBody]);
    }
    data.push(msgData);
  }
  var dataTotal = [];
  if (clearSheet==true) {
    dataTotal.push(['subject', 'date', 'message']);
  }
  for(var n in data){
    dataTotal = dataTotal.concat(data[n]);
  };
  Logger.log(JSON.stringify(dataTotal));
  if (clearSheet==true) {
    sh.clearContents();
    sh.getRange(1,1,dataTotal.length,dataTotal[0].length).setValues(dataTotal);
  }else{
    sh.getRange(sh.getLastRow()+1,1,dataTotal.length,dataTotal[0].length).setValues(dataTotal);
  }
}