Как получить курсы обмена валют через API, например Google Finance?

Я нашел API Google Finance и начал просматривать его, но нашел много информации о портфелях, сделках, позициях и других вещах, о которых ничего не знаю.

Я смотрю не на те документы? Что мне нужно сделать, чтобы получить информацию о курсах валют от GF? Это вообще возможно?

РЕДАКТИРОВАТЬ

Чтобы сделать вещи немного яснее. Я не заинтересован в технических вещах и не хочу никакого кода.

10 ответов

Решение

Спасибо за все ваши ответы.

Бесплатная валютная конвертация:

  • Цены обновляются каждые 30 минут
  • Нет учетной записи требуется

Пример URL конверсии: http://free.currencyconverterapi.com/api/v5/convert?q=EUR_USD&compact=y


Для потомков здесь они наряду с другими возможными ответами:

  1. 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.

  2. ( спасибо Keyo). Yahoo Query Language позволяет получить целую кучу валют одновременно в XML или JSON. Данные обновляются с точностью до секунды (в то время как у Европейского центрального банка есть данные за день) и останавливаются на выходных. Не требует никакой регистрации.

    http://query.yahooapis.com/v1/public/yql?q=select * from yahoo.finance.xchange где пара в ("USDEUR", "USDJPY", "USDBGN", "USDCZK", "USDDKK", "USDGBP", "USDHUF", "USDLTL", "USDLVL", "USDPLN", "USDRON", "USDSEK", "USDCHF", "USDNOK", "USDHRK", "USDRUB", "USDTRY", "USDAUD", "USDBRL", "USDCAD", "USDCNY", "USDHKD", "USDIDR", "USDILS", "USDINR", "USDKRW", "USDMXN", "USDMYR", "USDNZD", "USDPHP", "USDSGD", "USDTHB", "USDZAR", "USDISK")&env=store://datatables.org/alltableswithkeys

    Здесь YQL-конструктор запросов, где вы можете проверить запрос и скопировать URL: (НЕТ ДОЛГО ДОСТУПНО)

    http://developer.yahoo.com/yql/console/?q=show%20tables&env=store://datatables.org/alltableswithkeys

  1. 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 ...
      }
    }
    
  2. 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
          }
      }
    
  3. Fixer.io API (данные Европейского центрального банка)

    Бесплатный план на 1000 ежемесячных показов
    Смена "источника" (от "USD") в бесплатной учетной записи не допускается. Требуется регистрация.

    Эта конечная точка API устарела и перестанет работать 1 июня 2018 года. Для получения дополнительной информации, пожалуйста, посетите: https://github.com/fixerAPI/fixer#readme)


    Сайт: http://fixer.io/
    Пример запроса: http://api.fixer.io/latest?base=USD
    Собирает только одно значение за каждый день

  4. Европейский центральный банк 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. Я заметил, что данные обновляются с точностью до минуты, когда ЕЦБ хранит данные за один день и останавливается на выходных.

http://query.yahooapis.com/v1/public/yql?q=select%20%2A%20from%20yahoo.finance.xchange%20where%20pair%20in%20%28%22USDEUR%22,%20%22USDJPY%22,%20%22USDBGN%22,%20%22USDCZK%22,%20%22USDDKK%22,%20%22USDGBP%22,%20%22USDHUF%22,%20%22USDLTL%22,%20%22USDLVL%22,%20%22USDPLN%22,%20%22USDRON%22,%20%22USDSEK%22,%20%22USDCHF%22,%20%22USDNOK%22,%20%22USDHRK%22,%20%22USDRUB%22,%20%22USDTRY%22,%20%22USDAUD%22,%20%22USDBRL%22,%20%22USDCAD%22,%20%22USDCNY%22,%20%22USDHKD%22,%20%22USDIDR%22,%20%22USDILS%22,%20%22USDINR%22,%20%22USDKRW%22,%20%22USDMXN%22,%20%22USDMYR%22,%20%22USDNZD%22,%20%22USDPHP%22,%20%22USDSGD%22,%20%22USDTHB%22,%20%22USDZAR%22,%20%22USDISK%22%29&env=store://datatables.org/alltableswithkeys

Вот их конструктор запросов, где вы можете протестировать запрос и скопировать 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})"
Другие вопросы по тегам