Блог им. 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>
Данная публикация является личным мнением автора. Мнение владельца сайта может не совпадать с мнением автора.
630 | ★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:
Фото
Представляем интерактивный годовой отчет POSI по итогам 2025 года ✨
Друзья, в начале апреля мы раскрыли результаты прошлого года: опубликовали итоговую консолидированную финансовую и управленческую отчетность, а...
Фото
📃 Проверяем на цифрах актуальность стратегии «Продавай в мае и уходи»
Изначально стратегия появилась на западе. Летом инвестиционная активность снижается. Инвестор может продать акции в мае и уйти на каникулы...
Фото
От автопрома до инвестиционного портфеля
◻️ Платиноиды привычно ассоциируются с драгоценными украшениями . Однако главные сферы их применения лежат далеко за пределами витрин ювелирных...
Фото
Нефтяной срез: выпуск №9. Ормуз перекрыт, но акции нефтегаза падают. Надо ли покупать или сидеть на заборе в LQDT? Ищем лучших в секторе, где растет прибыль!
Продолжаю выпускать рубрику — Нефтяной срез.  Цель: отслеживать важные бенчмарки в нефтяной отрасли, чтобы понимать куда дует ветер.  Прошлый пост:...

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

....все тэги



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