March 24, 2021

Log everyday in google spreadsheet

I just wanted to create a daily task list with notes and reminders in google spreadsheet. So, I created a template which will look like this.

Now, I need to create a new sheet everyday where the sheet name will denote the day and after each month I needed it to back up in my google drive.

To solve this problem, I have created a app script which will create a new sheet everyday I open the spreadsheet and backup in a separate file.

My tasks will be

First, we need to create a clone of the template sheet.

1
2
3
4
5
6
7
8
9
10
11
12
13
function cloneTemplateDaily() {
var name = Utilities.formatDate(new Date(), "GMT", "dd-MM-yyyy");

var ss = SpreadsheetApp.getActiveSpreadsheet();
var duplicate_sheet = ss.getSheetByName(name);
if(duplicate_sheet == null) {
var templateSheet = ss.getSheetByName("template");
ss.setActiveSheet(templateSheet);
duplicate_sheet = ss.duplicateActiveSheet();
duplicate_sheet.setName(name);
}
ss.setActiveSheet(duplicate_sheet);
}

Then I need to backup the sheet to my google drive

1
2
3
4
5
6
7
8
9
10
11
12
13
14
function backupSheetMonthly() {
var lastMonthDate = getLastMonthDate();
var fileName = Utilities.formatDate(lastMonthDate, "GMT", "MMMM, yyyy");
var year = Utilities.formatDate(lastMonthDate, "GMT", "yyyy");

var rootFolder = getFolder("My Logs");
var yearFolder = getFolder(year, rootFolder);

if(!fileExist(fileName, yearFolder)) {
var file = DriveApp.getFileById(SpreadsheetApp.getActiveSpreadsheet().getId())
file.makeCopy(fileName, yearFolder);
deleteSheets();
}
}

Now, all the methods that I require

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
function fileExist(name, folder) {
var files = folder.getFilesByName(name);
while(files.hasNext()){
var file = files.next();
if(file.getName() == month) {
return true;
}
};
return false;
}

function getFolder(name, parent) {
var folders = null;
if(!parent) {
folders = DriveApp.getFoldersByName(name);
}
else {
folders = parent.getFoldersByName(name);
}

while(folders.hasNext()){
var folder = folders.next();
if(folder.getName() == name) {
return folder;
}
}

if(!parent) {
return DriveApp.createFolder(name);
}
return parent.createFolder(name);
}

function getLastMonthDate() {
var dt = new Date();
dt.setDate(0);
dt.setDate(1);
return dt;
}

function deleteSheets() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var sheets = ss.getSheets();
for(var i = 0; i < sheets.length; i++) {
if(sheets[i].getName() !== "template") {
ss.setActiveSheet(sheets[i]);
ss.deleteActiveSheet();
Utilities.sleep(100);
}
}
}

Lastly, I created two separate trigger that will call my two functions

  1. cloneTemplateDaily
  2. backupSheetMonthly

I set up a trigger poninted to From spreadsheet - On open cloneTemplateDaily so there will be a new sheet name current date with the same template

And a time based trigger that will run 1st of every month to run backupSheetMonthly function.

About this Post

This post is written by Mahfuzur Rahman, licensed under CC BY-NC 4.0.

#app script#spreadsheet