Акции расщепления API Google или Yahoo

Я ищу способ получить информацию о разделении акций. Используя фондовый API Yahoo, я могу получить любую информацию о любом символе, но не думаю, что смогу получить коэффициент разделения или даже разделить его. Кто-нибудь знает способ получения этой информации?

1 ответ

Решение

Вот как это делает пакет Quantmod R. Информация о разделении находится в CSV "Только для дивидендов":
http://ichart.finance.yahoo.com/x?s=IBM&a=00&b=2&c=1962&d=04&e=25&f=2011&g=v&y=0&z=30000

Вы можете легко сделать это в Python 3 с помощью пакета данных pandas. Приступаем к определению функции, которая будет возвращать историю разделения в виде фрейма данных:

def split_history(stock, date_start, date_end, limit_denominator=1000):
    from decimal import Decimal
    from fractions import Fraction
    from pandas_datareader import data as web
    df = web.DataReader(stock, data_source='yahoo-actions', start=date_start, end=date_end)
    is_split = df['action']=='SPLIT'
    df = df[is_split]
    ratios = []
    for index, row in df.iterrows():
        # Taking the inverse of the row['value'] as it is Yahoo finance convention
        ratio = Fraction(1/Decimal(row['value'])).limit_denominator(limit_denominator)
        ratios.append("{num} for {denom}".\
                            format(num=ratio.numerator, denom=ratio.denominator))
    df['ratio'] = ratios
    return df

Теперь мы можем получить разделение Microsoft ('MSFT') в качестве примера:

stock = 'MSFT'
date_start = '1987-01-01'
date_end = '2020-07-22'
split_history(stock, date_start, date_end)
            action  value       ratio
2003-02-18  SPLIT   0.500000    2 for 1
1999-03-29  SPLIT   0.500000    2 for 1
1998-02-23  SPLIT   0.500000    2 for 1
1996-12-09  SPLIT   0.500000    2 for 1
1994-05-23  SPLIT   0.500000    2 for 1
1992-06-15  SPLIT   0.666667    3 for 2
1991-06-27  SPLIT   0.666667    3 for 2
1990-04-16  SPLIT   0.500000    2 for 1
1987-09-21  SPLIT   0.500000    2 for 1

Он также правильно обрабатывает обратное деление приклада:

stock = 'PHM.MC'
split_history(stock, date_start, date_end)
                action  value   ratio
 2020-07-22     SPLIT   12.0    1 for 12

ps: возможно, есть более эффективные способы ввода дат. ps2: также limit_denominator нужен, чтобы избежать неправильного округления. Вы можете увеличить его в редких случаях.

Другие вопросы по тегам