myeia


Namemyeia JSON
Version 0.4.6 PyPI version JSON
download
home_pagehttps://github.com/philsv/myeia
SummaryPython Wrapper for the U.S. Energy Information Administration (EIA) APIv2.
upload_time2024-10-21 00:36:10
maintainerNone
docs_urlNone
authorphilsv
requires_pythonNone
licenseMIT
keywords eia eia-api open-data python
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # myeia

[![PyPI version](https://d25lcipzij17d.cloudfront.net/badge.svg?id=py&r=r&ts=1683906897&type=6e&v=0.4.6&x2=0)](https://badge.fury.io/py/myeia)
[![License: MIT](https://img.shields.io/badge/License-MIT-red.svg)](https://github.com/philsv/myeia/blob/main/LICENSE)
[![Weekly Downloads](https://static.pepy.tech/personalized-badge/myeia?period=week&units=international_system&left_color=grey&right_color=blue&left_text=downloads/week)](https://pepy.tech/project/myeia)
[![Monthly Downloads](https://static.pepy.tech/personalized-badge/myeia?period=month&units=international_system&left_color=grey&right_color=blue&left_text=downloads/month)](https://pepy.tech/project/myeia)
[![Downloads](https://static.pepy.tech/personalized-badge/myeia?period=total&units=international_system&left_color=grey&right_color=blue&left_text=downloads)](https://pepy.tech/project/myeia)

myeia is a simple Python wrapper for the U.S. Energy Information Administration (EIA) APIv2. It is designed to be simple to use and to provide a consistent interface for accessing EIA data.

## Installation

```ini
pip install myeia
```

## Requirements

* backoff
* pandas
* python-dateutil
* python-dotenv
* requests

## eia OPEN DATA Registration

To obtain an API Key you need to register on the [EIA website](https://www.eia.gov/opendata/register.php).

## eia API Query Browser

To find all EIA Datasets visit [API Dashboard](https://www.eia.gov/opendata/browser/).

## How to use

```python
from myeia import API

eia = API()
```

## Environment Variables

```bash
# Create a .env file in your projects root directory
touch .env
```

By default the `API` class will look for your `EIA_TOKEN`.

If you have registered for an API key you can set it in your `.env` file.

```ini
EIA_TOKEN=YOUR_TOKEN_HERE
```

## Get Series

Lets look at an example of how to get the *EIA Natural Gas Futures*.
You can use the simpler v1 API method where you only need to pass the `series_id` or you can use the newer v2 API method where you need to pass the `route`, `series`, and `frequency`.

```python
df = eia.get_series(series_id="NG.RNGC1.D")

df = eia.get_series_via_route(
    route="natural-gas/pri/fut",
    series="RNGC1",
    frequency="daily",
)

df.head()
```

Output Example:

```ini
            Natural Gas Futures Contract 1 (Dollars per Million Btu)
Date
2022-09-13                                              8.284
2022-09-12                                              8.249
2022-09-09                                              7.996
2022-09-08                                              7.915
2022-09-07                                              7.842
...                                                       ...
```

## Different Facets

Lets look at another example the *Total OPEC Petroleum Supply* where the facet is available as `seriesId`. By Default it is set as `series` but we can define the facet as `seriesId`.

```python
df = eia.get_series(series_id="STEO.PAPR_OPEC.M")

df = eia.get_series_via_route(
    route="steo",
    series="PAPR_OPEC",
    frequency="monthly",
    facet="seriesId",
)

df.head()
```

 Output Example:

```ini
            Total OPEC Petroleum Supply
Date
2023-12-01                    34.517314
2023-11-01                    34.440397
2023-10-01                    34.376971
2023-09-01                    34.416242
2023-08-01                    34.451823
...                                 ...
```

## Filter by multiple facets

You can also filter by multiple facets. Lets look at the *UAE Crude oil, NGPL, and other liquids* where the facets we choose are `countryRegionId` and `productId`.
The difference here is that both facet columns are present in the dataframe, unlike the previous examples where only one facet was present.

```python
df = eia.get_series_via_route(
    route="international",
    series=["ARE", 55],
    frequency="monthly",
    facet=["countryRegionId", "productId"],
)

df.head()
```

Output Example:

```ini
           countryRegionId productId  Crude oil, NGPL, and other liquids
Date                                                            
2024-03-01             ARE        55                         4132.394334
2024-02-01             ARE        55                         4132.394334
2024-01-01             ARE        55                         4142.394334
2023-12-01             ARE        55                         4082.394334
2023-11-01             ARE        55                         4082.394334
...                    ...       ...                                 ...
```

## Get Multiple Series

For multiple series you have to loop through the series and append the data to a list.

```python
data = []
for item in ["RNGC1", "RNGC2"]:
    df = eia.get_series_via_route(
    route="natural-gas/pri/fut",
    series=item,
    frequency="daily",
    facet="series",
    )
    data.append(df)

df = pd.concat(data, axis=1)
df.head()
```

Output Example:

```ini
            Natural Gas Futures Contract 1 (Dollars per Million Btu)  Natural Gas Futures Contract 2 (Dollars per Million Btu)
Date                                                                                                                  
2023-08-29                                              2.556                                                     2.662   
2023-08-28                                              2.579                                                     2.665   
2023-08-25                                              2.540                                                     2.657   
2023-08-24                                              2.519                                                     2.636   
2023-08-23                                              2.497                                                     2.592   
...                                                       ...                                                       ...
```

## Define a Start and End Date

You can define a start and end date for your query.

```python
df = eia.get_series(
    series_id="NG.RNGC1.D",
    start_date="2021-01-01",
    end_date="2021-01-31",
)

df.head()
```

Output Example:

```ini
            Natural Gas Futures Contract 1 (Dollars per Million Btu)
Date                                                        
2021-01-29                                              2.564   
2021-01-28                                              2.664   
2021-01-27                                              2.760   
2021-01-26                                              2.656   
2021-01-25                                              2.602   
...                                                       ...   
```

This also works for the `get_series_via_route` method.

```python
df = eia.get_series_via_route(
    route="natural-gas/pri/fut",
    series="RNGC1",
    frequency="daily",
    start_date="2021-01-01",
    end_date="2021-01-31",
)

df.head()
```

Output Example:

```ini
            Natural Gas Futures Contract 1 (Dollars per Million Btu)
Date
2021-01-29                                              2.564
2021-01-28                                              2.664
2021-01-27                                              2.760
2021-01-26                                              2.656
2021-01-25                                              2.602
...                                                       ...
```

## Contributing
We love your input! We want to make contributing to this project as easy and transparent as possible.
Read our [CONTRIBUTING.md](CONTRIBUTING.md) to get started.




            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/philsv/myeia",
    "name": "myeia",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "eia, eia-api, open-data, python",
    "author": "philsv",
    "author_email": "frphsv@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/54/e3/18b81b8b675f6c1b212441cf6a26c89cedad496afb6205eac8f2be5fc3e8/myeia-0.4.6.tar.gz",
    "platform": null,
    "description": "# myeia\n\n[![PyPI version](https://d25lcipzij17d.cloudfront.net/badge.svg?id=py&r=r&ts=1683906897&type=6e&v=0.4.6&x2=0)](https://badge.fury.io/py/myeia)\n[![License: MIT](https://img.shields.io/badge/License-MIT-red.svg)](https://github.com/philsv/myeia/blob/main/LICENSE)\n[![Weekly Downloads](https://static.pepy.tech/personalized-badge/myeia?period=week&units=international_system&left_color=grey&right_color=blue&left_text=downloads/week)](https://pepy.tech/project/myeia)\n[![Monthly Downloads](https://static.pepy.tech/personalized-badge/myeia?period=month&units=international_system&left_color=grey&right_color=blue&left_text=downloads/month)](https://pepy.tech/project/myeia)\n[![Downloads](https://static.pepy.tech/personalized-badge/myeia?period=total&units=international_system&left_color=grey&right_color=blue&left_text=downloads)](https://pepy.tech/project/myeia)\n\nmyeia is a simple Python wrapper for the U.S. Energy Information Administration (EIA) APIv2. It is designed to be simple to use and to provide a consistent interface for accessing EIA data.\n\n## Installation\n\n```ini\npip install myeia\n```\n\n## Requirements\n\n* backoff\n* pandas\n* python-dateutil\n* python-dotenv\n* requests\n\n## eia OPEN DATA Registration\n\nTo obtain an API Key you need to register on the [EIA website](https://www.eia.gov/opendata/register.php).\n\n## eia API Query Browser\n\nTo find all EIA Datasets visit [API Dashboard](https://www.eia.gov/opendata/browser/).\n\n## How to use\n\n```python\nfrom myeia import API\n\neia = API()\n```\n\n## Environment Variables\n\n```bash\n# Create a .env file in your projects root directory\ntouch .env\n```\n\nBy default the `API` class will look for your `EIA_TOKEN`.\n\nIf you have registered for an API key you can set it in your `.env` file.\n\n```ini\nEIA_TOKEN=YOUR_TOKEN_HERE\n```\n\n## Get Series\n\nLets look at an example of how to get the *EIA Natural Gas Futures*.\nYou can use the simpler v1 API method where you only need to pass the `series_id` or you can use the newer v2 API method where you need to pass the `route`, `series`, and `frequency`.\n\n```python\ndf = eia.get_series(series_id=\"NG.RNGC1.D\")\n\ndf = eia.get_series_via_route(\n    route=\"natural-gas/pri/fut\",\n    series=\"RNGC1\",\n    frequency=\"daily\",\n)\n\ndf.head()\n```\n\nOutput Example:\n\n```ini\n            Natural Gas Futures Contract 1 (Dollars per Million Btu)\nDate\n2022-09-13                                              8.284\n2022-09-12                                              8.249\n2022-09-09                                              7.996\n2022-09-08                                              7.915\n2022-09-07                                              7.842\n...                                                       ...\n```\n\n## Different Facets\n\nLets look at another example the *Total OPEC Petroleum Supply* where the facet is available as `seriesId`. By Default it is set as `series` but we can define the facet as `seriesId`.\n\n```python\ndf = eia.get_series(series_id=\"STEO.PAPR_OPEC.M\")\n\ndf = eia.get_series_via_route(\n    route=\"steo\",\n    series=\"PAPR_OPEC\",\n    frequency=\"monthly\",\n    facet=\"seriesId\",\n)\n\ndf.head()\n```\n\n Output Example:\n\n```ini\n            Total OPEC Petroleum Supply\nDate\n2023-12-01                    34.517314\n2023-11-01                    34.440397\n2023-10-01                    34.376971\n2023-09-01                    34.416242\n2023-08-01                    34.451823\n...                                 ...\n```\n\n## Filter by multiple facets\n\nYou can also filter by multiple facets. Lets look at the *UAE Crude oil, NGPL, and other liquids* where the facets we choose are `countryRegionId` and `productId`.\nThe difference here is that both facet columns are present in the dataframe, unlike the previous examples where only one facet was present.\n\n```python\ndf = eia.get_series_via_route(\n    route=\"international\",\n    series=[\"ARE\", 55],\n    frequency=\"monthly\",\n    facet=[\"countryRegionId\", \"productId\"],\n)\n\ndf.head()\n```\n\nOutput Example:\n\n```ini\n           countryRegionId productId  Crude oil, NGPL, and other liquids\nDate                                                            \n2024-03-01             ARE        55                         4132.394334\n2024-02-01             ARE        55                         4132.394334\n2024-01-01             ARE        55                         4142.394334\n2023-12-01             ARE        55                         4082.394334\n2023-11-01             ARE        55                         4082.394334\n...                    ...       ...                                 ...\n```\n\n## Get Multiple Series\n\nFor multiple series you have to loop through the series and append the data to a list.\n\n```python\ndata = []\nfor item in [\"RNGC1\", \"RNGC2\"]:\n    df = eia.get_series_via_route(\n    route=\"natural-gas/pri/fut\",\n    series=item,\n    frequency=\"daily\",\n    facet=\"series\",\n    )\n    data.append(df)\n\ndf = pd.concat(data, axis=1)\ndf.head()\n```\n\nOutput Example:\n\n```ini\n            Natural Gas Futures Contract 1 (Dollars per Million Btu)  Natural Gas Futures Contract 2 (Dollars per Million Btu)\nDate                                                                                                                  \n2023-08-29                                              2.556                                                     2.662   \n2023-08-28                                              2.579                                                     2.665   \n2023-08-25                                              2.540                                                     2.657   \n2023-08-24                                              2.519                                                     2.636   \n2023-08-23                                              2.497                                                     2.592   \n...                                                       ...                                                       ...\n```\n\n## Define a Start and End Date\n\nYou can define a start and end date for your query.\n\n```python\ndf = eia.get_series(\n    series_id=\"NG.RNGC1.D\",\n    start_date=\"2021-01-01\",\n    end_date=\"2021-01-31\",\n)\n\ndf.head()\n```\n\nOutput Example:\n\n```ini\n            Natural Gas Futures Contract 1 (Dollars per Million Btu)\nDate                                                        \n2021-01-29                                              2.564   \n2021-01-28                                              2.664   \n2021-01-27                                              2.760   \n2021-01-26                                              2.656   \n2021-01-25                                              2.602   \n...                                                       ...   \n```\n\nThis also works for the `get_series_via_route` method.\n\n```python\ndf = eia.get_series_via_route(\n    route=\"natural-gas/pri/fut\",\n    series=\"RNGC1\",\n    frequency=\"daily\",\n    start_date=\"2021-01-01\",\n    end_date=\"2021-01-31\",\n)\n\ndf.head()\n```\n\nOutput Example:\n\n```ini\n            Natural Gas Futures Contract 1 (Dollars per Million Btu)\nDate\n2021-01-29                                              2.564\n2021-01-28                                              2.664\n2021-01-27                                              2.760\n2021-01-26                                              2.656\n2021-01-25                                              2.602\n...                                                       ...\n```\n\n## Contributing\nWe love your input! We want to make contributing to this project as easy and transparent as possible.\nRead our [CONTRIBUTING.md](CONTRIBUTING.md) to get started.\n\n\n\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Python Wrapper for the U.S. Energy Information Administration (EIA) APIv2.",
    "version": "0.4.6",
    "project_urls": {
        "Homepage": "https://github.com/philsv/myeia"
    },
    "split_keywords": [
        "eia",
        " eia-api",
        " open-data",
        " python"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "f09f0611a6cef60d66203a20a3dbe080bc63e27411ddce5b46482e543872dba2",
                "md5": "14bc242761cb4554d0cffb33eb148662",
                "sha256": "115c6081a9dc7701e1c2345489de6d577fc03056ab1105bd73433ba4787eafe7"
            },
            "downloads": -1,
            "filename": "myeia-0.4.6-py2.py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "14bc242761cb4554d0cffb33eb148662",
            "packagetype": "bdist_wheel",
            "python_version": "py2.py3",
            "requires_python": null,
            "size": 6919,
            "upload_time": "2024-10-21T00:36:09",
            "upload_time_iso_8601": "2024-10-21T00:36:09.449399Z",
            "url": "https://files.pythonhosted.org/packages/f0/9f/0611a6cef60d66203a20a3dbe080bc63e27411ddce5b46482e543872dba2/myeia-0.4.6-py2.py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "54e318b81b8b675f6c1b212441cf6a26c89cedad496afb6205eac8f2be5fc3e8",
                "md5": "3c532727e95b3eebe4a5dd2560facd84",
                "sha256": "d7bdf88c70003e7b019d9c603316fbeac8c3ec4ee72d8ca4e622a9e5d0ecdbae"
            },
            "downloads": -1,
            "filename": "myeia-0.4.6.tar.gz",
            "has_sig": false,
            "md5_digest": "3c532727e95b3eebe4a5dd2560facd84",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 7885,
            "upload_time": "2024-10-21T00:36:10",
            "upload_time_iso_8601": "2024-10-21T00:36:10.978417Z",
            "url": "https://files.pythonhosted.org/packages/54/e3/18b81b8b675f6c1b212441cf6a26c89cedad496afb6205eac8f2be5fc3e8/myeia-0.4.6.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-10-21 00:36:10",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "philsv",
    "github_project": "myeia",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [],
    "lcname": "myeia"
}
        
Elapsed time: 0.67231s