Starting 16 May 2017, Yahoo finance has discontinued its well used service of EOD (end-of-day) data download without notice or warning. This is confirmed by Yahoo employee in this forum post.
However, EOD data still works on Yahoo finance pages. To download these data, you will now require "crumb" and cookie "B" for authentication. This code will obtain valid cookie and crumb and also downloads EOD price from Yahoo finance.
For python version, please visit code from c0redumb
The CSV format of the new API has a few difference compared to the original iChart source. Function Historical.Get
already taken care of this for you, BUT if you plan to use the raw data for further processing (Historical.GetRaw
function), check your code to make sure that followings differences are taken care of:
-
The historical data of Open, High, and Low are already adjusted. In older API download, these data fields are not adjusted.
-
The order of data fields in each row is slightly different. The fields of the new API are as following (note that the order of the last two fields are swapped from before).
Date, Open, High, Low, Close, Adjusted Close, Volume
- The order of the rows for historical quote by the new API is chronical (vs counter-chronical as the old API).
- Run build.bat to build DLL
- Copy bin\YahooFinanceAPI.dll and bin\YahooFinanceAPI.xml files into your Visual Studio project folder
- In Visual Studio, add reference YahooFinanceAPI.dll
using System.Threading.Tasks;
using YahooFinanceAPI;
using YahooFinanceAPI.Models;
...
private async Task GetHistoricalPrice(string symbol)
{
//first get a valid token from Yahoo Finance
while (string.IsNullOrEmpty(Token.Cookie) || string.IsNullOrEmpty(Token.Crumb))
{
await Token.RefreshAsync().ConfigureAwait(false);
}
var hps = await Historical.GetPriceAsync(symbol, DateTime.Now.AddMonths(-1), DateTime.Now).ConfigureAwait(false);
//do something
}
private async Task GetRawHistoricalPrice(string symbol)
{
//first get a valid token from Yahoo Finance
while (string.IsNullOrEmpty(Token.Cookie) || string.IsNullOrEmpty(Token.Crumb))
{
await Token.RefreshAsync().ConfigureAwait(false);
}
string csvdata = await Historical.GetRawAsync(symbol, DateTime.Now.AddMonths(-1), DateTime.Now).ConfigureAwait(false);
//process further
}
Imports System.Threading.Tasks
Imports YahooFinanceAPI
Imports YahooFinanceAPI.Models
...
Private Async Function GetHistoricalPrice(symbol As String) as Task
'first get a valid token from Yahoo Finance
While (Token.Cookie = "" OrElse Token.Crumb = "")
Await Token.RefreshAsync().ConfigureAwait(False)
End While
Dim hps = Await Historical.GetPriceAsync(symbol, DateTime.Now.AddMonths(-1), DateTime.Now).ConfigureAwait(False)
'do something
End Function
Private Async Function GetHistoricalPriceRaw(symbol As String) as Task
'first get a valid token from Yahoo Finance
While (Token.Cookie = "" OrElse Token.Crumb = "")
Await Token.RefreshAsync().ConfigureAwait(False)
End While
Dim csvdata = Await Historical.GetRawAsync(symbol, DateTime.Now.AddMonths(-1), DateTime.Now).ConfigureAwait(False)
'process further
End Function
This code is written by Dennis Lee