Блог им. AlekseyManin

Python. Как получить дату экспирации?

Пишу запросы на MOEX ISS, а там исторические данные(с прошедшей экспирацией) можно получить только с короткими названиями тикеров фьючерсов и опционов. Может кто-то уже писал код, чтобы вытащить дату экспирации из короткого названия тикера? Поделитесь пожалуйста.

Это один из запросов на MOEX:

<code>import requests

import apimoex
import pandas as pd

# request_url = ('http://iss.moex.com/iss/history/engines/futures/markets/options/securities.json?date=2021-12-01&assetcode=RIZ1')
request_url = ('http://iss.moex.com/iss/history/engines/futures/markets/options/securities.json?date=2021-12-01&assetcode=RTS')
arguments = {'securities.columns': (["BOARDID, TRADEDATE, SECID, OPEN, LOW, HIGH, CLOSE, OPENPOSITIONVALUE, VALUE, VOLUME, OPENPOSITION, SETTLEPRICE"])}

with requests.Session() as session:
    iss = apimoex.ISSClient(session, request_url, arguments)
    data = iss.get()
    df = pd.DataFrame(data['history'])
    df.set_index('SECID', inplace=True)
    print(df.to_string(max_rows=10, max_cols=15), '\n')
    df.info()</code>
622 | ★3
11 комментариев
Тебе на до за границу, питонщики сайтоделатели туда уехали
Старуха шепокляк, так я сайты не делаю ))) Да и что я там забыл в заграницах ваших )))
если никто не напишет, через минут30 скину
avatar
Андрей К, вот спасибо!!!
1) Нужно получить инфу по инструменту через apimoex.find_security_description

2) Обратиться к строке LSTTRADE у полученной таблицы.

Выглядит это примерно так. Тут я обращаюсь к константному номеру строки 6, но раньше вычислял эту строку автоматически (закомментил, наверное плохо работало)




avatar
Андрей К, всё получилось! Очень круто!!!



У меня так сделано:

from urllib.request import urlopen
import json

def get_date_of_last_trade(ticker):
url_str = 'https://iss.moex.com/iss/securities/{}.json'.format(ticker)
try:
j = urlopen(url_str)
except Exception as e:
print(e)
j_obj = json.load(j)
df_j = pd.DataFrame(j_obj['description']['data'], columns = j_obj['description']['columns'])
df_j = df_j[df_j['name'] == 'LSTTRADE']['value']
i = df_j.index[0]

return df_j.at[i]

avatar
Riskplayer, спасибо за ваш вариант!!!
Вы так хорошо знаете запросы к MOEX. Может можно сформировать запрос по фьючерсу, типа RIZ1, какие опционы на него торговались?
Или придется по дате экспирации опционов подбирать?
С этим не разбирался. Вроде как ранее обсуждалось вот это:
Вопрос по ISS Moex. Данные по опционам можно ли качать через ISS? (smart-lab.ru)
avatar
Riskplayer, историю опционов можно скачать. Меня интересуют итоги торгов за день с открытым интересом. Это есть.



Читайте на SMART-LAB:
ИНВЕСТИЦИИ И ТРЕНДЫ. ПЕРМЬ: ОНЛАЙН-ТРАНСЛЯЦИЯ
25 апреля в Перми проходит конференция «Финама» «Инвестиции и тренды-2026». Ее можно посмотреть онлайн из любой точки мира  👇 Смотреть в...
Обновление кредитных рейтингов в ВДО и розничных облигациях (ООО «РКС Девелопмент» повышен BBB.ru, ООО «СибАвтоТранс» понижен C|ru|, АО «Джи-групп» понижен ruBBB+)
🟢ООО «РКС Девелопмент» НКР повысило кредитный рейтинг с BBB-.ru до BBB.ru, прогноз — Стабильный (ранее Позитивный). ООО «РКС Девелопмент»...
Фото
📍 Сегодня — Profit Conf
Конференция уже началась, и команда МГКЛ работает на площадке. В 11:00 в зале №6 наше выступление — обзательно приходите послушать. И да,...
Фото
Обновляем стратегию 2026: год трудный, что изменилось, и в каком направлении мы движемся?
Квартальное обновление стратегии. Стратегия Mozgovik была представлена 17 января: https://smart-lab.ru/mobile/topic/1254157/ Что остается в...

теги блога Алексей Манин

....все тэги



UPDONW
Новый дизайн