A question I am often asked by users of GA4 Magic Reports (you can install it from here) is the following:
❓ Is there a way to add new data to the end of existing data when re-running a report?
This is because every time a report is run, the output is completely regenerated.
Anyway, the answer is simple: No.
But I don’t like simple things, and I especially don’t like not finding a solution to a problem that is brought to me…
✅ That’s why the answer becomes: Not directly, but here’s how you do it!
data:image/s3,"s3://crabby-images/f529e/f529e6e2651959e6c97fa36baaff3d2433f4896a" alt=""
Google Sheets has the quality of being able to use its own data management functions: you can use native Formulas and you can use Scripts. And we will use them! 😄
ℹ Therefore, we will make sure that the tool automatically creates a report with a specific name every day and collects the results of all generated reports in one sheet.
Proceed as follows:
☑ Create and configure a new report from the GA4 Magic Reports add-on interface as you normally do (and save it)
data:image/s3,"s3://crabby-images/2563b/2563b6894ca2970019eb386e0c4860368e185941" alt=""
☑ Replace the name of the report in the cell with this formula:
=”Report ” & YEAR(TODAY()) & MONTH(TODAY()) & DAY(TODAY())
data:image/s3,"s3://crabby-images/c74b4/c74b40d4f9ee8a92e1e116c2a28888b0c6709b4b" alt=""
This way the report name will be dynamic and will automatically update every day
☑ Schedule the report to run every day between 5 a.m. and 6 a.m.
data:image/s3,"s3://crabby-images/943e7/943e73cb55c09f15b4cf67bc3398f7f941565b45" alt=""
data:image/s3,"s3://crabby-images/7bc37/7bc37563323cc755ce9bbf2805dfe83ad2d091bc" alt=""
☑ From the “Extensions” menu of Google Sheet, select “Apps Script“
data:image/s3,"s3://crabby-images/d2aca/d2aca3869250ac62b048e3ec728b8100880e9cf7" alt=""
🎁 Copy and paste the code I have created:
function combineDataFromDynamicSheets() {
var sheetPrefix = "Report ";
var report_range = "A16:C";
var targetSheetName = "DataAggregator";
var ss = SpreadsheetApp.getActiveSpreadsheet();
var targetSheet = ss.getSheetByName(targetSheetName);
if (!targetSheet) {
targetSheet = ss.insertSheet(targetSheetName);
} else {
targetSheet.clear(); // Pulisce i dati esistenti nel foglio di destinazione
}
var combinedData = [];
var sheets = ss.getSheets(); // Ottiene tutti i fogli nel file
var regex = new RegExp("^" + sheetPrefix + "\\d+$"); // Crea la regex dinamica usando la variabile
for (var i = 0; i < sheets.length; i++) {
var sheet = sheets[i];
var sheetName = sheet.getName();
if (regex.test(sheetName)) {
var range = sheet.getRange(report_range);
var values = range.getValues();
for (var j = 0; j < values.length; j++) {
if (values[j][0] !== "") { // Considera solo le celle non vuote
combinedData.push([values[j][0],values[j][1],values[j][2]]);
}
}
}
}
if (combinedData.length > 0) {
targetSheet.getRange(1, 1, combinedData.length, 3).setValues(combinedData);
}
}
☑ Click on “Triggers” section
data:image/s3,"s3://crabby-images/c4818/c481808bb4988933a869466e10b18a0928555fae" alt=""
☑ Add a “Time-driven” one that automatically runs between 6 a.m. and 7 a.m.
data:image/s3,"s3://crabby-images/c1f15/c1f15cacc9b95f133821149a6adf16b5074d2fec" alt=""
That’s it! Easier done than said 🙂
🙌 You now have an automatic reporting system for GA4 that centralises all daily data extractions in one place!
Let me know how it sounds!
🎯 Follow me, Michele Pisani, for the more GA4/PPC insight
💌 Subscribe to my Newsletter: I know I Know Nothing
Commenti recenti