如何创建 google 应用脚本,在一段时间后删除临时联系人?
How to create a google app script that delete temporary contacts after a while?
我想创建一个执行以下操作的脚本:
- 删除标记为在特定时间后删除的联系人。
您肯定保存了一个 phone 号码,您只会使用一次,所以这有助于删除我们忘记的联系人。
好的,如果有人感兴趣,我正在回答我自己的问题。
首先,您必须创建一个联系人组,您将在其中对这些联系人进行分类(在代码中是 "Tiny",但您可以随意命名)。
其次,在创建联系人时,您应该添加注释,例如;如果您希望在 2 个月或“1 年”等之后删除联系人,则为“2 个月”。该代码仅在几个月和一年内实施,但如果您想要其他时间段(如几天或几周),则可以轻松修改。
代码如下:
function deleteTinyContacts() {
var group = ContactsApp.getContactGroup("Tiny");
var contacts = ContactsApp.getContactsByGroup(group)
var hoy = new Date();
Logger.log("today is " + hoy);
Logger.log("total contacts to delete: " + contacts.length);
for (var i = 0; i < contacts.length; i++) {
var date = contacts[i].getLastUpdated();
Logger.log(contacts[i].getFullName() + " was updated last in " + date);
var datediff = DateDiff.inMonths(date,hoy);
Logger.log("contact updated " + datediff + " months ago");
var note = contacts[i].getNotes();
var res = note.split(" ");
var Tmonths = calcMonths(res[1]);
var todelete = res[0]*Tmonths;
Logger.log("contact must be deleted after " + todelete + " months");
if (datediff>=todelete){
group.removeContact(contacts[i]);
}
}
}
var DateDiff = {
inDays: function(d1, d2) {
var t2 = d2.getTime();
var t1 = d1.getTime();
return parseInt((t2-t1)/(24*3600*1000));
},
inWeeks: function(d1, d2) {
var t2 = d2.getTime();
var t1 = d1.getTime();
return parseInt((t2-t1)/(24*3600*1000*7));
},
inMonths: function(d1, d2) {
var d1Y = d1.getFullYear();
var d2Y = d2.getFullYear();
var d1M = d1.getMonth();
var d2M = d2.getMonth();
return (d2M+12*d2Y)-(d1M+12*d1Y);
},
inYears: function(d1, d2) {
return d2.getFullYear()-d1.getFullYear();
}
}
function calcMonths(str){
if(str=="año"){return 12;}
else if(str=="mes"){return 1;}
}
我想创建一个执行以下操作的脚本:
- 删除标记为在特定时间后删除的联系人。
您肯定保存了一个 phone 号码,您只会使用一次,所以这有助于删除我们忘记的联系人。
好的,如果有人感兴趣,我正在回答我自己的问题。
首先,您必须创建一个联系人组,您将在其中对这些联系人进行分类(在代码中是 "Tiny",但您可以随意命名)。 其次,在创建联系人时,您应该添加注释,例如;如果您希望在 2 个月或“1 年”等之后删除联系人,则为“2 个月”。该代码仅在几个月和一年内实施,但如果您想要其他时间段(如几天或几周),则可以轻松修改。
代码如下:
function deleteTinyContacts() {
var group = ContactsApp.getContactGroup("Tiny");
var contacts = ContactsApp.getContactsByGroup(group)
var hoy = new Date();
Logger.log("today is " + hoy);
Logger.log("total contacts to delete: " + contacts.length);
for (var i = 0; i < contacts.length; i++) {
var date = contacts[i].getLastUpdated();
Logger.log(contacts[i].getFullName() + " was updated last in " + date);
var datediff = DateDiff.inMonths(date,hoy);
Logger.log("contact updated " + datediff + " months ago");
var note = contacts[i].getNotes();
var res = note.split(" ");
var Tmonths = calcMonths(res[1]);
var todelete = res[0]*Tmonths;
Logger.log("contact must be deleted after " + todelete + " months");
if (datediff>=todelete){
group.removeContact(contacts[i]);
}
}
}
var DateDiff = {
inDays: function(d1, d2) {
var t2 = d2.getTime();
var t1 = d1.getTime();
return parseInt((t2-t1)/(24*3600*1000));
},
inWeeks: function(d1, d2) {
var t2 = d2.getTime();
var t1 = d1.getTime();
return parseInt((t2-t1)/(24*3600*1000*7));
},
inMonths: function(d1, d2) {
var d1Y = d1.getFullYear();
var d2Y = d2.getFullYear();
var d1M = d1.getMonth();
var d2M = d2.getMonth();
return (d2M+12*d2Y)-(d1M+12*d1Y);
},
inYears: function(d1, d2) {
return d2.getFullYear()-d1.getFullYear();
}
}
function calcMonths(str){
if(str=="año"){return 12;}
else if(str=="mes"){return 1;}
}