我正在尝试获取有关我的 Gmail 帐户的一些报告,一切看起来都很好,除非我尝试使用正则表达式。
目标是从报告中获取信息,并将其粘贴到电子表格中,但是进行一些测试时,我发现有时它不会从 gmail 中检索任何内容(如果我将电子邮件正文粘贴到电子表格上,我会看到两三个和一个空白,二十封电子邮件,又是空白),所以我得到 NULL 作为正则表达式的结果。
谁能解释我做错了什么?这是我使用 Google App 脚本引擎的第一周。
提前致谢。
这是代码。
function recopilarInformes() {
var threads = GmailApp.search('label:informes');
var messages;
var ContentEmail;
var reportDate,CFree,FFree;
for (var i = 0; i < 20 /*threads.length*/; i++) {
messages = threads[i].getMessages()
reportDate = messages[0].getSubject().replace("Informe ","");
ContentEmail = messages[0].getBody();
CFree = /(\d+.\d+)\s.*GB/g(ContentEmail);
FFree = /F<.td><td\s\w+\W+\w+.\w+.>\s(\d+.\d+)/(ContentEmail);
Logger.log(reportDate);
Logger.log(/(\d+.\d+)\s.*GB/g(ContentEmail));
}
编辑
我得出的结论是,尽管我不知道如何准确地使用 google app 脚本中的 gmail 对象,但正则表达式并不是实现我的目标的最佳方式。
这是当前代码
function recopilarInformes() {
var threads = GmailApp.search('label:informes');
Logger.log(threads);
Logger.log(threads[0].getMessages());
Logger.log(threads[0].getMessages().length);
var messages;// = threads[0].getMessages();
var ContentEmail;// = messages[0].getBody();
var reportDate,CFree,FFree;
for (var i = 0; i < threads.length; i++) {
messages = threads[i].getMessages()
reportDate = messages[0].getSubject().replace("Informe ","");//creo si hubiera más mensajes en la conversación (thread) habría más entradas en este array, que ahora mismso solo contiene una cosa
ContentEmail = messages[0].getBody();
Logger.log(reportDate);
// Logger.log(/(\d+.\d+)\s.*GB/g(ContentEmail));
actualData = ContentEmail.split("------------ Espacio en las unidades -----------")[1];
actualData = actualData.replace(/([^ 0-9,])/g,"").trim().replace(/\s+/g," ").split(" ");
insertValue([reportDate,actualData[0],actualData[1]]);
}
}