Pobierz listę spotkań angielskiej Premier League
/**
* @fileoverview Example of using Sportsradar API to get English Premier League
* soccer schedules, to use in adjusting campaigns.
* The principles of this example could easily be reused against any of the
* sports feeds available from Sportradar.
*
* Example: Get fixtures on 1st Oct 2016
* const schedule = getSoccerSchedule(2016, 10, 1);
*
* See https://developers.google.com/google-ads/scripts/docs/features/third-party-apis#working_with_api_responses
* See http://developer.sportradar.us/
*/
// Replace with the API Key found on your Sportradar API Application page.
const API_KEY = 'ENTER_API_KEY';
// Insert your email address here for notification of API request failures.
const EMAIL_ADDRESS = 'ENTER_EMAIL_ADDRESS';
const VERSION = 2;
const LEAGUE = 'eu';
// Set to false when no longer in trial mode.
const TRIAL_MODE = true;
/**
* Retrieves a list of fixtures from the Soccer Schedule API.
* @param {number} year The year for which to get matches, in the form yyyy.
* @param {number} month The month for which to get matches, in range 1-12.
* @param {number} day The day for which to get matches, in range 1-31.
* @return {!Array.<!Object>} An array of object containing fixture info or
* null if the request was unsuccessful.
*/
function getSoccerSchedule(year, month, day) {
const urlTemplate =
'https://api.sportradar.us/soccer-%s%d/%s/matches/%d/%02d/%02d/schedule.xml?api_key=%s';
const accessLevel = TRIAL_MODE ? 't' : 'p';
const url = Utilities.formatString(
urlTemplate, accessLevel, VERSION, LEAGUE, year, month, day, API_KEY);
const response = UrlFetchApp.fetch(url);
return parseScheduleXml(response.getContentText());
}
/**
* Converts the date format returned from the XML feed into a Date object.
* @param {string} scheduleDate A date from the feed e.g. 2016-07-11T17:00:00Z
* @return {!Date} The resulting Date object.
*/
function parseScheduleDate(scheduleDate) {
return new Date(
scheduleDate.replace(/-/g, '/').replace('T', ' ').replace('Z', ' GMT'));
}
/**
* Parses the schedule XML, identifying only English Premier League Soccer
* matches, as an example of selecting events on which to make Google Ads
* changes.
* @param {string} xmlText XML response body from a call to the soccer schedule
* API.
* @return {!Array.<!Object>} An array of object containing fixture info.
*/
function parseScheduleXml(xmlText) {
const fixtures = [];
const scheduleElement = XmlService.parse(xmlText).getRootElement();
// The namespace is required for accessing child elements in the schema.
const namespace = scheduleElement.getNamespace();
const matchesElement = scheduleElement.getChild('matches', namespace);
const matchElements = matchesElement.getChildren();
for (let i = 0, matchElement; matchElement = matchElements[i]; i++) {
const status = matchElement.getAttribute('status').getValue();
const scheduled = matchElement.getAttribute('scheduled').getValue();
const scheduledDate = parseScheduleDate(scheduled);
const categoryElement = matchElement.getChild('category', namespace);
const country = categoryElement.getAttribute('country').getValue();
const tournamentElement = matchElement.getChild('tournament', namespace);
const tournamentName = tournamentElement.getAttribute('name').getValue();
if (tournamentName === 'Premier League' && country === 'England') {
const homeElement = matchElement.getChild('home', namespace);
const awayElement = matchElement.getChild('away', namespace);
const homeTeamName = homeElement.getAttribute('name').getValue();
const awayTeamName = awayElement.getAttribute('name').getValue();
fixtures.push({
date: scheduledDate,
homeTeam: homeTeamName,
awayTeam: awayTeamName
});
}
}
return fixtures;
}