Iterators
Stay organized with collections
Save and categorize content based on your preferences.
Iterators are a common programming pattern used for traversing a list of objects
when
- The size of the list may not be known from the start.
- Loading the entire list into memory at once may prove overly resource
intensive.
Iterators expose two methods: boolean hasNext()
and Object next()
.
Google Ads scripts use the Iterator pattern for fetching Google Ads entities.
Functionally, iterators are not too different from regular arrays, and can make
your code more concise. Compare the code that traverses an array:
for (var i = 0; i < myArray.length; i++) {
let myObject = myArray[i];
}
with code that traverses an iterator:
while (myIterator.hasNext()) {
let myObject = myIterator.next();
}
The following code demonstrates the usage of an iterator over all Search and
Display campaigns in your account:
var campaignIterator = AdsApp.campaigns().get();
while (campaignIterator.hasNext()) {
let campaign = campaignIterator.next();
console.log(`${campaign.getName()}; active? ${campaign.isEnabled()}; ` +
`budget=${campaign.getBudget().getAmount()}`);
}
You can also use built-in JavaScript iteration:
for (const campaign of AdsApp.campaigns()) {
console.log(`${campaign.getName()}; active? ${campaign.isEnabled()}; ` +
`budget=${campaign.getBudget().getAmount()}`);
}
Application of withLimit()
to a selector does not change the value of
totalNumEntities()
. x
and y
in the following snippet will have the same
value:
var x = AdsApp.keywords().get().totalNumEntities();
var y = AdsApp.keywords().withLimit(5).get().totalNumEntities();
In order to obtain an Iterator of Google Ads entities, you must construct a
Selector first.
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2025-08-22 UTC.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-08-22 UTC."],[[["\u003cp\u003eIterators in Google Ads scripts are used to efficiently process lists of objects, especially when dealing with large or unknown-sized datasets, by fetching entities one at a time.\u003c/p\u003e\n"],["\u003cp\u003eThey offer two primary methods, \u003ccode\u003ehasNext()\u003c/code\u003e to check for more items and \u003ccode\u003enext()\u003c/code\u003e to retrieve the next item, similar to how arrays are traversed but without loading the entire list into memory.\u003c/p\u003e\n"],["\u003cp\u003eThe Google Ads scripts utilize the Iterator pattern for accessing and manipulating various Google Ads entities like campaigns, allowing for streamlined processing and resource management.\u003c/p\u003e\n"],["\u003cp\u003eWhile applying \u003ccode\u003ewithLimit()\u003c/code\u003e to a selector constrains the number of fetched entities, it doesn't affect the overall count obtained via \u003ccode\u003etotalNumEntities()\u003c/code\u003e.\u003c/p\u003e\n"],["\u003cp\u003eTo retrieve an Iterator of Google Ads objects, you first need to define a Selector that specifies the desired entities and their properties.\u003c/p\u003e\n"]]],[],null,["Iterators are a common programming pattern used for traversing a list of objects when\n\n- The size of the list may not be known from the start.\n- Loading the entire list into memory at once may prove overly resource intensive.\n\nIterators expose two methods: `boolean hasNext()` and `Object next()`.\nGoogle Ads scripts use the Iterator pattern for fetching Google Ads entities.\n\nFunctionally, iterators are not too different from regular arrays, and can make\nyour code more concise. Compare the code that traverses an array: \n\n for (var i = 0; i \u003c myArray.length; i++) {\n let myObject = myArray[i];\n }\n\nwith code that traverses an iterator: \n\n while (myIterator.hasNext()) {\n let myObject = myIterator.next();\n }\n\nThe following code demonstrates the usage of an iterator over all Search and\nDisplay campaigns in your account: \n\n var campaignIterator = AdsApp.campaigns().get();\n\n while (campaignIterator.hasNext()) {\n let campaign = campaignIterator.next();\n console.log(`${campaign.getName()}; active? ${campaign.isEnabled()}; ` +\n `budget=${campaign.getBudget().getAmount()}`);\n }\n\nYou can also use built-in JavaScript iteration: \n\n for (const campaign of AdsApp.campaigns()) {\n console.log(`${campaign.getName()}; active? ${campaign.isEnabled()}; ` +\n `budget=${campaign.getBudget().getAmount()}`);\n }\n\nApplication of `withLimit()` to a selector does not change the value of\n`totalNumEntities()`. `x` and `y` in the following snippet will have the same\nvalue: \n\n var x = AdsApp.keywords().get().totalNumEntities();\n var y = AdsApp.keywords().withLimit(5).get().totalNumEntities();\n\nIn order to obtain an Iterator of Google Ads entities, you must construct a\n[Selector](/google-ads/scripts/docs/concepts/selectors) first."]]