Можно вызвать webread
от функций, которые вы задаете. Лучшая практика состоит в том, чтобы позволить вашей функции передавать опции запроса HTTP webread
.
Этот пример кода показывает, как загрузить данные климата для страны. Выборка задает функцию в файле с именем worldBankTemps.m
, который загружает ежегодные температуры с World Bank и преобразовывает их в градусы по Фаренгейту. Можно передать дополнительные параметры запроса HTTP с входным параметром options
. options
является объектом weboptions
, который worldBankTemps
передает webread
. Можно вызвать worldBankTemps
с названием страны только, когда вы не должны задавать никакие другие параметры запроса HTTP.
function temperatures = worldBankTemps(country,options) % Get World Bank temperatures for a country, for example, 'USA'. api = 'http://climatedataapi.worldbank.org/climateweb/rest/v1/'; api = [api 'country/cru/tas/year/']; country = [api country]; % The options object contains additional HTTP % request parameters. If worldBankTemps was % not passed options as an input argument, % create a default weboptions object. if ~exist('options','var') options = weboptions; end s = webread(country,options); % Convert data to arrays temperatures = struct('Years',[],'DegreesInFahrenheit',[]); temperatures(1).Years = [s.year]; temperatures(1).DegreesInFahrenheit = [s.data]; % Convert temperatures to Fahrenheit temperatures(1).DegreesInFahrenheit = temperatures(1).DegreesInFahrenheit * 9/5 + 32; end
Чтобы получить температурные данные для США, вызовите worldBankTemps
. Если связь с веб-сервисом World Bank испытывает таймаут, сервис возвращает сообщение об ошибке.
S = worldBankTemps('USA')
Error using webread (line 112) The connection to URL 'http://climatedataapi.worldbank.org/climateweb/rest/v1/country/cru/tas/year/USA' timed out after 5.0 seconds. Set options.Timeout to a higher value.
Если вы создаете options
и устанавливаете его свойство Timeout
на 60 секунд, то можно вызвать worldBankTemps
снова с options
как входной параметр. worldBankTemps
передает options
webread
как входной параметр. На этот раз webread
сохраняет связь открытой максимум для 60 секунд.
options = weboptions('Timeout',60); S = worldBankTemps('USA',options)
S = Years: [1x112 double] DegreesInFahrenheit: [1x112 double]
Если ваш код не позволяет вам передавать опции запроса webread
, который ограничивает вашу способность ответить на сообщения об ошибке, возвращенные веб-сервисами.
Когда вы используете функцию веб-сервиса в MATLAB®, функциональная сила возвращает сообщение об ошибке, которое советует вам устанавливать свойство options
, такого как options.Timeout
Тайм-аут. Эта таблица показывает некоторые типичные сообщения об ошибке, которые относятся к свойствам options
и мерам, которые можно принять в ответ.
Сообщение об ошибке содержит фразу | Действие, которое будет взято |
---|---|
|
|
|
|
... |
|