It turns out, the MLB has every team's full schedule in an easy to parse CSV format. All you need to do is search Google for "
The link you need is circled in the image above. You can see from the url what the team_id value should be in the code below. And if you right-click and download that .csv file, you will be able to see what value to use for the home_field as well. In the example below, I used my hometown teams of the Cubs and the White Sox, but you can use any teams you want.
The script itself will run through and look for a home game for your team. If the team is playing today and it is a home game, it will enable any ads that are tagged with the label you configured in the TEAM_INFO. If the team isn't playing a home game today, it will pause those same ads.
In the example below, I only used a portion of the data in the csv files. It would also be possible to enable ads only during the actual game, or enable ads for all game days, not just home games.
I encourage you to play around with the data and see what you can come up with. If you find anything useful, please leave a comment.
Thanks,
Russ
//----------------------------------- // Enable/Disable Ads Based on the MLB Schedule // Created By: Russ Savage // FreeAdWordsScripts.com //----------------------------------- function main() { var TEAM_INFO = [ { team_id : 112, home_field : 'Wrigley Field', label : 'cubs' }, // Cubs { team_id : 145, home_field : 'U.S. Cellular Field', label : 'whitesox' } // White Sox ]; //hopefully you've already created and tagged some ads with these labels //but just in case... createLabelsIfNeeded(TEAM_INFO); var SEASON = (new Date()).getFullYear(); var is_home = false, is_game_day = false; for(var t in TEAM_INFO) { var team = TEAM_INFO[t]; var url = "http://mlb.mlb.com/soa/ical/schedule.csv?team_id="+team.team_id+"&season="+SEASON; var html = UrlFetchApp.fetch(url).getContentText(); var date_list = html.split("\r\n"); for(var i in date_list) { if(i == 0) {continue;} var [start_date,start_time,start_time_et, subject,location,description, end_date,end_date_et,end_time,end_time_et] = date_list[i].split(","); var today = new Date(); var game_day = new Date(); game_day.setFullYear(SEASON,parseInt(start_date.split("/")[0])-1,parseInt(start_date.split("/")[1])); is_home = (location == team.home_field); is_game_day = (diffDays(game_day,today) == 0); if(is_home && is_game_day) { enableBaseballAds(team.label); break; } } if(!(is_home && is_game_day)) { disableBaseballAds(team.label); } } } function enableBaseballAds(label) { Logger.log("Enabling all ads with the "+label+" label."); var ads = AdWordsApp.ads().withCondition("LabelNames CONTAINS_ALL ['"+label+"']").get(); while(ads.hasNext()) { ads.next().enable(); } } function disableBaseballAds(label) { Logger.log("Disabling all ads with the "+label+" label."); var ads = AdWordsApp.ads().withCondition("LabelNames CONTAINS_ALL ['"+label+"']").get(); while(ads.hasNext()) { ads.next().pause(); } } function createLabelsIfNeeded(team_info) { var label_iter = AdWordsApp.labels().get(); var label_list = []; while(label_iter.hasNext()) { label_list.push(label_iter.next().getName()); } for(var i in team_info) { if(label_list.indexOf(team_info[i].label) == -1) { AdWordsApp.createLabel(team_info[i].label); label_list.push(team_info[i].label); } } } //A helper function to compare dates. //Copied from: http://goo.gl/uW48a function diffDays(firstDate,secondDate) { var oneDay = 24*60*60*1000; // hours*minutes*seconds*milliseconds return Math.round(Math.abs((firstDate.getTime() - secondDate.getTime())/(oneDay))); }