>백엔드 개발 >파이썬 튜토리얼 >Python으로 옵션 흐름 시각화: 단계별 가이드

Python으로 옵션 흐름 시각화: 단계별 가이드

WBOY
WBOY원래의
2024-09-08 06:33:03978검색

Visualizing Options Flow with Python: A Step-by-Step Guide

계속 진화하는 금융 세계에서 데이터 시각화는 시장 동향에 대한 전례 없는 통찰력을 제공할 수 있습니다. 이 기사에서는 Yahoo Finance의 과거 데이터를 사용하여 특정 주식에 대한 옵션 흐름을 시각화하는 특정 재무 분석 작업에 Python을 활용하는 방법을 살펴보겠습니다. 우리는 콜옵션과 풋옵션의 흐름을 설명하기 위해 옵션 데이터를 가져와서 처리하고 분산형 차트를 생성하는 코드 조각을 사용할 것입니다. 자세한 내용을 살펴보겠습니다.

시작하기

우리의 목표는 특정 주식에 대한 옵션 데이터를 분석하고 이를 분산형 차트로 시각화하는 것입니다. 이 예에서는 주식 시세 표시기 LLY(Eli Lilly and Company)를 사용합니다. 코드 조각은 다음을 수행합니다.

  1. 지정된 주식에 대한 최신 옵션 데이터를 검색합니다.
  2. 데이터를 필터링하고 정리합니다.
  3. 시간 경과에 따른 콜 옵션과 풋 옵션을 나타내는 분산형 차트를 만듭니다.

단계별 분석

1. 라이브러리 가져오기

먼저 필요한 라이브러리를 가져와야 합니다.

import yfinance as yf
import os
from datetime import datetime, timedelta
import matplotlib.pyplot as plt
import pandas as pd
  • yfinance는 과거 주식 데이터를 가져오는 데 사용됩니다.
  • os는 디렉터리 및 파일 작업을 처리합니다.
  • datetime과 timedelta는 날짜 관리용입니다.
  • matplotlib.pyplot은 시각화 생성을 위한 것입니다.
  • pandas는 데이터 조작 및 분석을 위한 것입니다.

2. 디렉터리 및 파일 설정

데이터를 저장할 출력 디렉터리와 파일을 설정합니다.

output_directory = 'output'
os.makedirs(output_directory, exist_ok=True)
output_file = os.path.join(output_directory, 'output.data')

여기서 출력 디렉터리가 있는지 확인하고 데이터 파일의 경로를 지정합니다.

3. 옵션 데이터 가져오기 및 처리

LLY 종목에 대한 옵션 데이터를 얻으려면 yfinance를 사용합니다.

ticker = 'LLY'
days = 21
populate_data = 'Y'  # Set 'N' to use existing file, 'Y' to create new file

populate_data가 'Y'로 설정된 경우 코드는 새 옵션 데이터를 가져옵니다. 'N'인 경우 기존 데이터 파일을 사용합니다.

데이터 가져오기 및 처리가 수행되는 방법은 다음과 같습니다.

if populate_data == 'Y':
    stock = yf.Ticker(ticker)
    options_dates = stock.options

    today = datetime.now()
    fourteen_days_later = today + timedelta(days)

    with open(output_file, 'w') as file:
        for date in options_dates:
            date_dt = datetime.strptime(date, '%Y-%m-%d')
            if today <= date_dt <= fourteen_days_later:
                calls = stock.option_chain(date).calls
                puts = stock.option_chain(date).puts

                for _, row in calls.iterrows():
                    if not filter_volume(row['volume']):
                        file.write(f"Call,{date},{row['strike']},{row['volume']}\n")

                for _, row in puts.iterrows():
                    if not filter_volume(row['volume']):
                        file.write(f"Put,{date},{row['strike']},{row['volume']}\n")

    print(f"Data has been written to {output_file}")

이 코드는 콜옵션 및 풋옵션 데이터를 가져와서 원치 않는 거래량 데이터가 있는 행을 필터링한 후 파일에 씁니다.

4. 시각화를 위한 데이터 정리 및 준비

다음으로 데이터를 읽고 정리합니다.

data = pd.read_csv(output_file, names=['Type', 'Last_Trade_Date', 'Strike', 'Volume'])
data.dropna(inplace=True)
data['Last_Trade_Date'] = pd.to_datetime(data['Last_Trade_Date'])
data = data[data['Volume'].notna()]

우리는 데이터세트에 NaN 값이 없고 Last_Trade_Date가 올바른 날짜/시간 형식인지 확인합니다.

5. 산점도 만들기

분산형 차트를 만들 준비가 되었습니다.

extra_days_before = 5
extra_days_after = 5

min_date = data['Last_Trade_Date'].min() - timedelta(days=extra_days_before)
max_date = data['Last_Trade_Date'].max() + timedelta(days=extra_days_after)

plt.figure(figsize=(12, 8))

calls_data = data[data['Type'] == 'Call']
plt.scatter(calls_data['Last_Trade_Date'], calls_data['Strike'],
            s=calls_data['Volume'], c='green', alpha=0.6, label='Call')

puts_data = data[data['Type'] == 'Put']
plt.scatter(puts_data['Last_Trade_Date'], puts_data['Strike'],
            s=puts_data['Volume'], c='red', alpha=0.6, label='Put')

plt.xlabel('\nLast Trade Date')
plt.ylabel('Strike Price\n')
plt.title(f'Options Flow for {ticker} ({days} days)\n', fontsize=16)
plt.xticks(rotation=45, ha='right')
plt.gca().xaxis.set_major_formatter(plt.matplotlib.dates.DateFormatter('%Y-%m-%d'))
plt.xlim(min_date, max_date)
plt.subplots_adjust(bottom=0.2)
plt.grid(True)

plt.text(0.5, 0.5, f'{ticker}', color='gray', fontsize=80, alpha=0.5,
         ha='center', va='center', rotation=15, transform=plt.gca().transAxes)
plt.text(0.95, 0.95, 'medium.com/@dmitry.romanoff', color='gray', fontsize=20, alpha=0.5,
         ha='right', va='top', transform=plt.gca().transAxes)
plt.text(0.05, 0.05, 'medium.com/@dmitry.romanoff', color='gray', fontsize=20, alpha=0.5,
         ha='left', va='bottom', transform=plt.gca().transAxes)

plot_file = os.path.join(output_directory, 'options_scatter_plot.png')
plt.savefig(plot_file)

print(f"Scatter plot has been saved to {plot_file}")

이 세그먼트는 y축에 행사 가격, x축에 거래 날짜를 포함하는 콜 옵션과 풋 옵션의 산점도를 생성합니다. 포인트의 크기는 거래량을 나타내며 녹색은 콜, 빨간색은 풋을 나타냅니다. 또한 브랜딩 목적으로 워터마크를 추가하고 플롯을 파일에 저장합니다.

결론

옵션 데이터를 시각화하면 거래자와 분석가가 시장 심리와 거래 활동을 이해하는 데 도움이 됩니다. 이 가이드에서는 Python을 사용하여 옵션 데이터를 가져오고, 처리하고, 시각화하는 방법을 보여주었습니다. 다음 단계를 따르면 이 코드를 모든 주식에 적용하고 옵션 흐름을 분석하여 시장 동향에 대한 귀중한 통찰력을 얻을 수 있습니다.

특정 요구 사항에 맞게 코드를 자유롭게 수정하고 재무 데이터를 시각화하는 다양한 방법을 찾아보세요.

위 내용은 Python으로 옵션 흐름 시각화: 단계별 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.