Created
January 6, 2016 11:47
-
-
Save pilbot/9d0567ef1daf556449fb to your computer and use it in GitHub Desktop.
Using the Google Apps Script Cache Service for objects above 100Kb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
function ChunkyCache(cache, chunkSize){ | |
return { | |
put: function (key, value, timeout) { | |
var json = JSON.stringify(value); | |
var cSize = Math.floor(chunkSize / 2); | |
var chunks = []; | |
var index = 0; | |
while (index < json.length){ | |
cKey = key + "_" + index; | |
chunks.push(cKey); | |
cache.put(cKey, json.substr(index, cSize), timeout+5); | |
index += cSize; | |
} | |
var superBlk = { | |
chunkSize: chunkSize, | |
chunks: chunks, | |
length: json.length | |
}; | |
cache.put(key, JSON.stringify(superBlk), timeout); | |
}, | |
get: function (key) { | |
var superBlkCache = cache.get(key); | |
if (superBlkCache != null) { | |
var superBlk = JSON.parse(superBlkCache); | |
chunks = superBlk.chunks.map(function (cKey){ | |
return cache.get(cKey); | |
}); | |
if (chunks.every(function (c) { return c != null; })){ | |
return JSON.parse(chunks.join('')); | |
} | |
} | |
} | |
}; | |
}; | |
function testGetCacheFrom(){ | |
var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Data'); | |
var data = sheet.getDataRange().getValues(); | |
var chunky = ChunkyCache(CacheService.getDocumentCache(), 1024*90); | |
chunky.put('Data', data, 120); | |
var check = chunky.get('Data'); | |
var sheetPut = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Out'); | |
for (c in check) { | |
sheetPut.appendRow(check[c]); | |
} | |
} |
@RealSlimMahdi , I have the same code =)
https://gist.github.com/contributorpw/afbd50ad22767c7b758ceda94c53e393
@RealSlimMahdi , I have the same code =)
https://gist.github.com/contributorpw/afbd50ad22767c7b758ceda94c53e393
Haha funny @contributorpw, your doc is better =]
@RealSlimMahdi , look at the remove method. They are identical =)
Yes, I have seen 🤝
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Hi, thank you very much for this piece of code, me too I wish GAS would allow bigger caching space:
I had to add a remove method for my project and linted the code, so I am sharing here in case someone needs it someday: