Skip to main content

EPİAŞ (Turkish Electricity Market) transparency platform data API client

Project description

pyepias

A Python client library for accessing EPİAŞ (Turkish Electricity Market) transparency platform data.

Overview

pyepias provides a simple and intuitive interface to fetch electricity market data from the EPİAŞ (Enerji Piyasaları İşletme A.Ş.) transparency platform. This library handles authentication and data retrieval, making it easy to access market clearing prices and other electricity market data.

Features

  • 🔐 Automatic authentication with EPİAŞ platform
  • 📊 Fetch Market Clearing Price (MCP) data
  • 📅 Support for multiple time periods (today, week, month, custom range)
  • 📈 Built-in statistical analysis
  • 🐼 Pandas DataFrame integration
  • 📄 JSON export support

Installation

From PyPI (when published)

pip install pyepias

From source

git clone https://github.com/cagrigungor/pyepias.git
cd pyepias
pip install -e .

Install dependencies only

pip install -r requirements.txt

Quick Start

from pyepias import EpiasClient

# Initialize the client with your EPİAŞ credentials
client = EpiasClient("your@email.com", "your_password")

# Get today's market clearing prices
data = client.download(period="today")
print(data)

Usage Examples

Get data for different time periods

from pyepias import EpiasClient

client = EpiasClient("your@email.com", "your_password")

# Today's data
today_data = client.download(period="today")

# Last week's data
week_data = client.download(period="week")

# Last month's data
month_data = client.download(period="month")

Custom date range

from datetime import datetime
from pyepias import EpiasClient

client = EpiasClient("your@email.com", "your_password")

# Define custom date range
start_date = datetime(2024, 1, 1)
end_date = datetime(2024, 1, 10)

# Get data for custom range
data = client.download(period=(start_date, end_date))

Get JSON output instead of DataFrame

from pyepias import EpiasClient

client = EpiasClient("your@email.com", "your_password")

# Get data as JSON string
json_data = client.download(
    period="today",
    output_format="json"
)
print(json_data)

Get statistical summary

from pyepias import EpiasClient

client = EpiasClient("your@email.com", "your_password")

# Get statistics for the last week
stats = client.stats(period="week")

print(f"Average Price (TL): {stats['mean_price_tl']:.2f}")
print(f"Min Price (TL): {stats['min_price_tl']:.2f}")
print(f"Max Price (TL): {stats['max_price_tl']:.2f}")
print(f"Total Records: {stats['total_records']}")

Data analysis with pandas

from pyepias import EpiasClient
import matplotlib.pyplot as plt

client = EpiasClient("your@email.com", "your_password")

# Get last month's data
df = client.download(period="month")

# Analyze the data
print(df.describe())

# Plot the data
df.plot(x='date', y='price', kind='line', title='Market Clearing Prices')
plt.ylabel('Price (TL/MWh)')
plt.show()

API Reference

EpiasClient

Main client class for interacting with EPİAŞ transparency platform.

Constructor

EpiasClient(email: str, password: str)

Parameters:

  • email (str): Your EPİAŞ account email
  • password (str): Your EPİAŞ account password

Methods

download()
download(
    period: Union[str, Tuple[datetime, datetime]] = "today",
    output_format: str = "dataframe"
) -> Union[pd.DataFrame, str, None]

Download Market Clearing Price (MCP) data.

Parameters:

  • period: Time period for data retrieval
    • "today": Today's data
    • "week": Last 7 days
    • "month": Last 30 days
    • (start_date, end_date): Custom date range as tuple of datetime objects
  • output_format: Output format - "dataframe" or "json"

Returns:

  • pd.DataFrame, str, or None: Market data in requested format
stats()
stats(
    period: Union[str, Tuple[datetime, datetime]] = "today"
) -> Optional[Dict[str, float]]

Get statistical summary of market clearing prices.

Parameters:

  • period: Time period (same as download)

Returns:

  • dict: Dictionary containing statistical measures:
    • mean_price_tl: Average price in TL
    • min_price_tl: Minimum price in TL
    • max_price_tl: Maximum price in TL
    • median_price_tl: Median price in TL
    • std_price_tl: Standard deviation of price in TL
    • total_records: Number of records
    • mean_price_eur: Average price in EUR (if available)
    • mean_price_usd: Average price in USD (if available)

Requirements

  • Python >= 3.7
  • requests >= 2.25.0
  • pandas >= 1.2.0

About EPİAŞ

EPİAŞ (Enerji Piyasaları İşletme A.Ş.) is the operator of Turkish electricity markets. The transparency platform provides public access to various electricity market data including market clearing prices, production data, consumption data, and more.

Note: You need to register on the EPİAŞ Transparency Platform to obtain credentials for using this library.

Author

Hasan Çağrı Güngör

License

This project is licensed under the MIT License - see the LICENSE file for details.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

Disclaimer

This library is not officially associated with EPİAŞ. Use at your own risk and make sure to comply with EPİAŞ terms of service.

Changelog

v0.1.0 (Initial Release)

  • Basic client implementation
  • Market Clearing Price (MCP) data retrieval
  • Support for multiple time periods
  • Statistical analysis features
  • JSON and DataFrame output formats

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyepias-0.1.0.tar.gz (6.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyepias-0.1.0-py3-none-any.whl (7.1 kB view details)

Uploaded Python 3

File details

Details for the file pyepias-0.1.0.tar.gz.

File metadata

  • Download URL: pyepias-0.1.0.tar.gz
  • Upload date:
  • Size: 6.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.8

File hashes

Hashes for pyepias-0.1.0.tar.gz
Algorithm Hash digest
SHA256 3f5702662c762dcf9089ef974d00c14b9242eb0d2468364597cac185926f7004
MD5 0e1d035af506859c79aae9ca11019ef1
BLAKE2b-256 67e58a9939cd0c7a2c23f99df4185df5cb25659b1f20d1449290cdd46e5a620d

See more details on using hashes here.

File details

Details for the file pyepias-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: pyepias-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 7.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.8

File hashes

Hashes for pyepias-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ab8a1f230f92a7b21b969276638709f9f65758e48e8d7346b1d952c50999d031
MD5 c7b930e43634401ed53adb2fae959952
BLAKE2b-256 e99d8047fd72e40995a064ca2dc2c9394d9cb7c898ad6b32e3547551609e417e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page