首页 > 解决方案 > 从gmail中提取线程中的所有消息到电子表格中

问题描述

我正在尝试利用此代码从我的收件箱中提取求职者数据并填充谷歌表格。这很容易,但问题是应用程序首先由我们的网站插件处理,然后发送到我的收件箱。这会将发件人更改为相同的地址。谷歌将每个收件人添加到同一个线程,然后阻止代码从每个到达的应用程序中提取信息。

目前,正在检索每条消息的第一条。我知道我需要实现一个循环来遍历线程,但到目前为止我还没有运气。

在此处记入我的原始代码源

这是到目前为止的代码:

此功能将过滤器、已解析的内容传送到活动工作表。

function gather() {
    var messages = getGmail();
    var curSheet = SpreadsheetApp.getActive();
    messages.forEach(message => {curSheet.appendRow(parseEmail(message))});
}

它在这些功能之一的某个地方我认为需要合并一个循环来收集线程中的所有消息

    function getGmail() {
        const query = "from:noreply-careers@smooth.ie ";
    
        let threads = GmailApp.search(query);
    
        //let label = GmailApp.getUserLabelByName("done");
        //if (!label) {label = GmailApp.createLabel("done")}
    
        let messages = [];
    
        threads.forEach(thread => {
            messages.push(thread.getMessages()[0].getPlainBody());
            
        });
    
        return messages;
    }

具体来说,我一直在关注这一点,以包括通过线程的循环和消息:

    threads.forEach(thread => {
        messages.push(thread.getMessages()[0].getPlainBody());

我确实尝试过这样的事情,但我无法让它工作。

function getGmails_(query) {
    var emails = [];
    var threads = GmailApp.search(query);
    for (var i in threads) {
        var msgs = threads[i].getMessages();
        for (var j in msgs) {
            emails.push([msgs[j].getPlainBody().replace(/\n*\s.+:/,',')
            .replace(/\n*.+:/g,',')
            .replace(/^,/,'')
            .replace(/\n/g,'')
            .split(',')
          ]);
        
        }
    } 
  
    return result;
}

其余代码正在运行一些正则表达式,以从消息正文中提取申请人的答案,并封装在索引中以传递到工作表中的列。

function parseEmail(message){
    var parsed = message.replace(/,/g,'')
        .replace(/\n*.+:/g,',')
        .replace(/^,/,'')
        .replace(/\n/g,'')
        .split(',');

    var result = [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22].map(index => parsed[index]);

    return result;
    
}

标签: javascriptparsinggoogle-apps-scriptgoogle-sheetsextract

解决方案


如果您只想检索单个数组中所有线程中所有消息的普通正文,您可以这样做:

  • 对于GmailThread.getMessages()中返回的每条消息,使用map返回一个数组,其中包含每条消息的相应纯正文。
  • 使用push将当前线程消息的普通正文添加到主messages数组。

代码片段:

threads.forEach(thread => {
  const threadMessages = thread.getMessages().map(message=>message.getPlainBody());
  messages.push(...threadMessages);
});

推荐阅读