Как получить курсы обмена валют через API, например Google Finance?
Я нашел API Google Finance и начал просматривать его, но нашел много информации о портфелях, сделках, позициях и других вещах, о которых ничего не знаю.
Я смотрю не на те документы? Что мне нужно сделать, чтобы получить информацию о курсах валют от GF? Это вообще возможно?
РЕДАКТИРОВАТЬ
Чтобы сделать вещи немного яснее. Я не заинтересован в технических вещах и не хочу никакого кода.
10 ответов
Спасибо за все ваши ответы.
Бесплатная валютная конвертация:
- Цены обновляются каждые 30 минут
- Нет учетной записи требуется
Пример URL конверсии: http://free.currencyconverterapi.com/api/v5/convert?q=EUR_USD&compact=y
Для потомков здесь они наряду с другими возможными ответами:
API финансов YahooСнято с производства 2017-11-06Прекращено с 2017-11-06 с сообщением
Нам стало известно, что эта служба используется с нарушением Условий предоставления услуг Yahoo. Таким образом, услуга прекращается. Для всех будущих исследований рынка и акций, пожалуйста, обратитесь к finance.yahoo.com.
Запрос: http://finance.yahoo.com/d/quotes.csv?e=.csv&f=sl1d1t1&s=USDINR=X
Этот CSV использовался плагином jQuery под названием Curry. С тех пор (2017-08-29) Карри перешел на использование fixer.io из-за проблем со стабильностью. Может быть полезно, если вам нужно больше, чем просто CSV.( спасибо Keyo). Yahoo Query Language позволяет получить целую кучу валют одновременно в XML или JSON. Данные обновляются с точностью до секунды (в то время как у Европейского центрального банка есть данные за день) и останавливаются на выходных. Не требует никакой регистрации.
Здесь
YQL-конструктор запросов, где вы можете проверить запрос и скопировать URL: (НЕТ ДОЛГО ДОСТУПНО)http://developer.yahoo.com/yql/console/?q=show%20tables&env=store://datatables.org/alltableswithkeys
API с открытым исходным кодом
Бесплатно для личного пользования (1000 просмотров в месяц)
Изменение "базы" (от "USD") в бесплатном аккаунте не допускается
Требуется регистрация.
Запрос: http://openexchangerates.org/latest.json
Отклик:{ "disclaimer": "This data is collected from various providers ...", "license": "all code open-source under GPL v3 ...", "timestamp": 1323115901, "base": "USD", "rates": { "AED": 3.66999725, "ALL": 102.09382091, "ANG": 1.78992886, // 115 more currency rates here ... } }
Currencylayer API
Бесплатный план на 1000 ежемесячных показов
Смена "источника" (из "USD") в бесплатном аккаунте запрещена.
Требуется регистрация.
Документация: http://currencylayer.com/documentation
Ответ JSON:{ [...] "timestamp": 1436284516, "source": "USD", "quotes": { "USDAUD": 1.345352401, "USDCAD": 1.27373397, "USDCHF": 0.947845302, "USDEUR": 0.91313905, "USDGBP": 0.647603397, // 168 world currencies } }
Fixer.io API (данные Европейского центрального банка)
Бесплатный план на 1000 ежемесячных показов
Смена "источника" (от "USD") в бесплатной учетной записи не допускается. Требуется регистрация.Эта конечная точка API устарела и перестанет работать 1 июня 2018 года. Для получения дополнительной информации, пожалуйста, посетите: https://github.com/fixerAPI/fixer#readme)
Сайт: http://fixer.io/
Пример запроса: http://api.fixer.io/latest?base=USD
Собирает только одно значение за каждый деньЕвропейский центральный банк Feed
Документы: http://www.ecb.int/stats/exchange/eurofxref/html/index.en.html
Запрос: http://www.ecb.int/stats/eurofxref/eurofxref-daily.xml
Ответ XML:<Cube> <Cube time="2015-07-07"> <Cube currency="USD" rate="1.0931"/> <Cube currency="JPY" rate="133.88"/> <Cube currency="BGN" rate="1.9558"/> <Cube currency="CZK" rate="27.100"/> </Cube>
Европейский центральный банк (ЕЦБ) также имеет самый надежный бесплатный корм, который я знаю. Он содержит около 28 валют и обновляется как минимум ежедневно.
http://www.ecb.int/stats/eurofxref/eurofxref-daily.xml
Дополнительные форматы и инструменты см. На справочной странице ECB: http://www.ecb.int/stats/exchange/eurofxref/html/index.en.html
У Yahoo есть функция YQL, позволяющая получать сразу несколько валют в формате XML или JSON. Я заметил, что данные обновляются с точностью до минуты, когда ЕЦБ хранит данные за один день и останавливается на выходных.
Вот их конструктор запросов, где вы можете протестировать запрос и скопировать URL:
http://developer.yahoo.com/yql/console/?q=show%20tables&env=store://datatables.org/alltableswithkeys
Если вам нужен бесплатный и простой API для конвертации одной валюты в другую, попробуйте http://free.currencyconverterapi.com/.
Отказ от ответственности, я автор сайта, и я использую его для одного из моих других сайтов.
Услуга бесплатна для использования даже в коммерческих целях, но не дает никаких гарантий. По соображениям производительности значения обновляются только каждый час.
Пример URL преобразования: http://free.currencyconverterapi.com/api/v5/convert?q=EUR_PHP&compact=ultra который будет возвращать значение в формате json, например {"EUR_PHP":60.849184}
Я получил этот контент с http://www.scriptarticle.com/2012/05/03/get-live-currency-rates-and-currency-conversion-using-php-and-apis/
<?php
function get_currency($from_Currency, $to_Currency, $amount) {
$amount = urlencode($amount);
$from_Currency = urlencode($from_Currency);
$to_Currency = urlencode($to_Currency);
$url = "http://www.google.com/finance/converter?a=$amount&from=$from_Currency&to=$to_Currency";
$ch = curl_init();
$timeout = 0;
curl_setopt ($ch, CURLOPT_URL, $url);
curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt ($ch, CURLOPT_USERAGENT,
"Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1)");
curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
$rawdata = curl_exec($ch);
curl_close($ch);
$data = explode('bld>', $rawdata);
$data = explode($to_Currency, $data[1]);
return round($data[0], 2);
}
// Call the function to get the currency converted
echo get_currency('USD', 'INR', 1);
?>
Вот некоторые API обмена с примером PHP.
[ Открыть API курсов валют ]
Обеспечивает 1000 запросов в месяц бесплатно. Вы должны зарегистрироваться и получить идентификатор приложения. Базовая валюта USD для бесплатного аккаунта. Проверьте поддерживаемые валюты и документацию.
// open exchange URL // valid app_id * REQUIRED *
$exchange_url = 'https://openexchangerates.org/api/latest.json';
$params = array(
'app_id' => 'YOUR_APP_ID'
);
// make cURL request // parse JSON
$curl = curl_init();
curl_setopt_array($curl, array(
CURLOPT_URL => $exchange_url . '?' . http_build_query($params),
CURLOPT_RETURNTRANSFER => true
));
$response = json_decode(curl_exec($curl));
curl_close($curl);
if (!empty($response->rates)) {
// convert 150 USD to JPY ( Japanese Yen )
echo $response->rates->JPY * 150;
}
150 долларов США = 18039,09015 иен
[ Валютный уровень API ]
Обеспечивает 1000 запросов в месяц бесплатно. Вы должны зарегистрироваться и получить ключ доступа. Пользовательская базовая валюта не поддерживается в бесплатном аккаунте. Проверьте документацию.
$exchange_url = 'http://apilayer.net/api/live';
$params = array(
'access_key' => 'YOUR_ACCESS_KEY',
'source' => 'USD',
'currencies' => 'JPY',
'format' => 1 // 1 = JSON
);
// make cURL request // parse JSON
$curl = curl_init();
curl_setopt_array($curl, array(
CURLOPT_URL => $exchange_url . '?' . http_build_query($params),
CURLOPT_RETURNTRANSFER => true
));
$response = json_decode(curl_exec($curl));
curl_close($curl);
if (!empty($response->quotes)) {
// convert 150 USD to JPY ( Japanese Yen )
echo '150 USD = ' . $response->quotes->USDJPY * 150 . ' JPY';
}
150 долларов США = 18036,75045 иен
Вы можете попробовать геоглугин
Помимо геолокации, выполняемой IP (но IP - это IP-адрес провайдера, поэтому не очень точный), они также возвращают валюты и имеют конвертер валют: см. Примеры.
Они обновили 111 валют.
Вот один простой скрипт PHP, который получает обменный курс между GBP и USD
<?php
$amount = urlencode("1");
$from_GBP0 = urlencode("GBP");
$to_usd= urlencode("USD");
$Dallor = "hl=en&q=$amount$from_GBP0%3D%3F$to_usd";
$US_Rate = file_get_contents("http://google.com/ig/calculator?".$Dallor);
$US_data = explode('"', $US_Rate);
$US_data = explode(' ', $US_data['3']);
$var_USD = $US_data['0'];
echo $to_usd;
echo $var_USD;
echo '<br/>';
?>
Курсы валют Google не точны, сам Google говорит ==> Google не может гарантировать точность курсов обмена, используемых калькулятором. Вам следует подтвердить текущие курсы, прежде чем совершать какие-либо транзакции, на которые могут повлиять изменения обменных курсов. Курсы иностранных валют, предоставляемые Citibank NA, отображаются по лицензии. Цены указаны только в информационных целях и могут быть изменены без предварительного уведомления. Тарифы на реальные транзакции могут отличаться, и Ситибанк не предлагает вступать в какие-либо транзакции по любой указанной ставке.
Для всех новичков, которые ищут какой-то намек на конвертацию валюты, взгляните на эту ссылку. Datavoila
Это очень помогло относительно моего собственного проекта на C#. На случай, если сайт исчезнет, я добавлю код ниже. Просто добавьте следующие шаги в ваш собственный проект. Извините за форматирование.
const string fromCurrency = "USD";
const string toCurrency = "EUR";
const double amount = 49.95;
// For other currency symbols see http://finance.yahoo.com/currency-converter/
// Clear the output editor //optional use, AFAIK
Output.Clear();
// Construct URL to query the Yahoo! Finance API
const string urlPattern = "http://finance.yahoo.com/d/quotes.csv?s={0}{1}=X&f=l1";
string url = String.Format(urlPattern, fromCurrency, toCurrency);
// Get response as string
string response = new WebClient().DownloadString(url);
// Convert string to number
double exchangeRate =
double.Parse(response, System.Globalization.CultureInfo.InvariantCulture);
// Output the result
Output.Text = String.Format("{0} {1} = {2} {3}",
amount, fromCurrency,
amount * exchangeRate, toCurrency);
Если вы ищете решение на основе ruby для этой проблемы, я рекомендую использовать метод Google Calculator, решение, похожее на следующее: http://j.mp/QIC564
require 'faraday'
require 'faraday_middleware'
require 'json'
# Debug:
# require "pry"
country_code_src = "USD"
country_code_dst = "INR"
connection = Faraday.get("http://www.google.com/ig/calculator?hl=en&q=1#{country_code_src}=?#{country_code_dst}")
currency_comparison_hash = eval connection.body #Google's output is not JSON, it's a hash
dst_currency_value, *dst_currency_text = *currency_comparison_hash[:rhs].split(' ')
dst_currency_value = dst_currency_value.to_f
dst_currency_text = dst_currency_text.join(' ')
puts "#{country_code_dst} -> #{dst_currency_value} (#{dst_currency_text} to 1 #{country_code_src})"