investpy


Nameinvestpy JSON
Version 1.0.8 PyPI version JSON
download
home_pagehttps://investpy.readthedocs.io/
SummaryFinancial Data Extraction from Investing.com with Python
upload_time2022-01-24 16:43:39
maintainer
docs_urlNone
authorAlvaro Bartolome
requires_python>=3.7
licenseMIT License
keywords investing investing-api historical-data financial-data stocks funds etfs indices currency crosses bonds commodities crypto currencies
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <p align="center">
  <img src="https://raw.githubusercontent.com/alvarobartt/investpy/master/docs/source/_static/logo.png" hspace="20">
</p>

<h2 align="center">Financial Data Extraction from Investing.com with Python</h2>

investpy is a Python package to retrieve data from [Investing.com](https://www.investing.com/), which provides data retrieval 
from up to 39952 stocks, 82221 funds, 11403 ETFs, 2029 currency crosses, 7797 indices, 688 bonds, 66 commodities, 250 certificates, 
and 4697 cryptocurrencies.

investpy allows the user to download both recent and historical data from all the financial products indexed at Investing.com. 
**It includes data from all over the world**, from countries such as United States, France, India, Spain, Russia, or Germany, 
amongst many others.

investpy seeks to be one of the most complete Python packages when it comes to financial data extraction to stop relying 
on public/private APIs since investpy is **FREE** and has **NO LIMITATIONS**. These are some of the features that currently lead 
investpy to be one of the most consistent packages when it comes to financial data retrieval.

[![Python Version](https://img.shields.io/pypi/pyversions/investpy.svg)](https://pypi.org/project/investpy/)
[![PyPI Version](https://img.shields.io/pypi/v/investpy.svg)](https://pypi.org/project/investpy/)
[![Package Status](https://img.shields.io/pypi/status/investpy.svg)](https://pypi.org/project/investpy/)
[![Build Status](https://github.com/alvarobartt/investpy/workflows/run_tests/badge.svg)](https://github.com/alvarobartt/investpy/actions?query=workflow%3Arun_tests)
[![Documentation Status](https://readthedocs.org/projects/investpy/badge/?version=latest)](https://investpy.readthedocs.io/)

**If you want to support the project, you can buy the developer a coffee. More information at: [buy-me-a-coffee](https://github.com/alvarobartt/buy-me-a-coffee)**

<p align="center"><a href="https://www.buymeacoffee.com/alvarobartt" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/default-orange.png" alt="Buy Me A Coffee" height="41" width="174"></a></p>

---

## :hammer_and_wrench: Installation

To get this package working you will need to **install it via pip** (with a Python 3.6 version or higher) on the terminal by typing:

``$ pip install investpy``

Additionally, **if you want to use the latest investpy version instead of the stable one, you can install it from source** with the following command:

``$ pip install git+https://github.com/alvarobartt/investpy.git@master``

**The master branch ensures the user that the most updated version will always be working and fully operative** so as not to wait until the 
the stable release comes out (which eventually may take some time depending on the number of issues to solve).

---

## :computer: Usage

Even though some investpy usage examples are presented on the [docs](https://investpy.readthedocs.io/usage.html), 
some basic functionality will be sorted out with sample Python code blocks. Additionally, more usage examples 
can be found under [examples/](https://github.com/alvarobartt/investpy/tree/master/examples) directory, which 
contains a collection of Jupyter Notebooks on how to use investpy and handle its data.

:pushpin: __Note that `investpy.search_quotes` is the only function that ensures that the data is updated and aligned 1:1 with
the data provided by Investing.com!__

### :chart_with_upwards_trend: Recent/Historical Data Retrieval

investpy allows the user to **download both recent and historical data from any financial product indexed** 
(stocks, funds, ETFs, currency crosses, certificates, bonds, commodities, indices, and cryptos). In 
the example presented below, the historical data from the past years of a stock is retrieved. 

```python
import investpy

df = investpy.get_stock_historical_data(stock='AAPL',
                                        country='United States',
                                        from_date='01/01/2010',
                                        to_date='01/01/2020')
print(df.head())
```
```{r, engine='python', count_lines}
             Open   High    Low  Close     Volume Currency
Date                                                      
2010-01-04  30.49  30.64  30.34  30.57  123432176      USD
2010-01-05  30.66  30.80  30.46  30.63  150476160      USD
2010-01-06  30.63  30.75  30.11  30.14  138039728      USD
2010-01-07  30.25  30.29  29.86  30.08  119282440      USD
2010-01-08  30.04  30.29  29.87  30.28  111969192      USD
```

To get to know all the available recent and historical data extraction functions provided by 
investpy, and also, parameter tuning, please read the docs.

### :mag: Search Live Data

**Investing.com search engine is completely integrated** with investpy, which means that any available 
financial product (quote) can be easily found. The search function allows the user to tune the parameters 
to adjust the search results to their needs, where both product types and countries from where the 
products are, can be specified. **All the search functionality can be easily used**, for example, as 
presented in the following piece of code:

```python
import investpy

search_result = investpy.search_quotes(text='apple', products=['stocks'],
                                       countries=['united states'], n_results=1)
print(search_result)
```
```json
{"id_": 6408, "name": "Apple Inc", "symbol": "AAPL", "country": "united states", "tag": "/equities/apple-computer-inc", "pair_type": "stocks", "exchange": "NASDAQ"}
```

Retrieved search results will be a `list` of `investpy.utils.search_obj.SearchObj` class instances, unless
`n_results` is set to 1, when just a single `investpy.utils.search_obj.SearchObj` class instance will be returned.
To get to know which are the available functions and attributes of the returned search results, please read the related 
documentation at [Search Engine Documentation](https://investpy.readthedocs.io/search_api.html). So on, those 
search results let the user retrieve both recent and historical data, its information, the technical indicators,
the default currency, etc., as presented in the piece of code below:

```python
recent_data = search_result.retrieve_recent_data()
historical_data = search_result.retrieve_historical_data(from_date='01/01/2019', to_date='01/01/2020')
information = search_result.retrieve_information()
default_currency = search_result.retrieve_currency()
technical_indicators = search_result.retrieve_technical_indicators(interval='daily')
```

### :money_with_wings: Crypto Currencies Data Retrieval

Cryptocurrencies support has recently been included, to let the user retrieve data and information from any 
available crypto at Investing.com. Please note that some cryptocurrencies do not have available data indexed 
at Investing.com so that it can not be retrieved using investpy either, even though they are just a few, 
consider it.

As already presented previously, **historical data retrieval using investpy is really easy**. The piece of code 
presented below shows how to retrieve the past years of historical data from Bitcoin (BTC).

```python
import investpy

data = investpy.get_crypto_historical_data(crypto='bitcoin',
                                           from_date='01/01/2014',
                                           to_date='01/01/2019')

print(data.head())
```
```{r, engine='python', count_lines}
             Open    High    Low   Close  Volume Currency
Date                                                     
2014-01-01  805.9   829.9  771.0   815.9   10757      USD
2014-01-02  815.9   886.2  810.5   856.9   12812      USD
2014-01-03  856.9   888.2  839.4   884.3    9709      USD
2014-01-04  884.3   932.2  848.3   924.7   14239      USD
2014-01-05  924.7  1029.9  911.4  1014.7   21374      USD
```

---

## :open_book: Documentation

You can find the **complete investpy documentation** at [Documentation](https://investpy.readthedocs.io/).

---

## :sparkles: Contribute

As this is an open-source project it is **open to contributions, bug reports, bug fixes, documentation improvements, 
enhancements, and ideas**. There is an open tab of [issues](https://github.com/alvarobartt/investpy/issues) where 
anyone can open new issues if needed or navigate through them to solve them or contribute to its solving. 
Remember that issues are not threads to describe multiple problems, this does not mean that issues can not 
be discussed, but so to keep structured project management, the same issue should not describe different 
problems, just the main one and some nested/related errors that may be found.

---

## :question: Discussions (Q&A, AMA)

GitHub recently released a new feature named __GitHub Discussions__ (still in beta). GitHub Discussions is a 
collaborative communication forum for the community around an open source project.

Check the investpy GitHub Discussions page at [Discussions](https://github.com/alvarobartt/investpy/discussions), 
and feel free to ask me (ar any developer) anything, share updates, have open-ended conversations, and follow along 
on decisions affecting the community's way of working.

:pushpin: __Note__. Usually I don't answer emails asking me questions about investpy, as we currently have the
GitHub Discussions tab, and I encourage you to use it. GitHub Discussions is the easiest way to contact me about 
investpy, so that I don't answer the same stuff more than once via email, as anyone can see the opened/answered
discussions.

---

## :card_index_dividers: Related projects

Since investpy is intended to retrieve data from different financial products as indexed in Investing.com, 
the **development of some support modules which implement an additional functionality based on investpy data**, 
is presented. Note that **anyone can contribute to this section** by creating any package, module, or utility that 
uses investpy. So on, the ones already created are going to be presented, since they are intended to be used 
combined with investpy:

- [pyrtfolio](https://github.com/alvarobartt/pyrtfolio/): is a Python package to generate stock portfolios.
- [trendet](https://github.com/alvarobartt/trendet/): is a Python package for trend detection on stock time-series data.

If you developed an interesting/useful project based on investpy data, please open an issue to let me know to 
include it in this section.

---

## :memo: Citation

When citing this repository on your scientific publications please use the following **BibTeX** citation:

```bibtex
@misc{investpy,
    author = {Alvaro Bartolome del Canto},
    title = {investpy - Financial Data Extraction from Investing.com with Python},
    year = {2018-2021},
    publisher = {GitHub},
    journal = {GitHub Repository},
    howpublished = {\url{https://github.com/alvarobartt/investpy}},
}
```

When citing this repository on any other social media, please use the following citation:

```
investpy - Financial Data Extraction from Investing.com with Python developed by Alvaro Bartolome del Canto
```

You should also mention the source from where the data is retrieved, Investing.com; even though it's already
included in the package short description title.

---

## :man_technologist: Contact Information

You can contact me at any of my social network profiles:

- :briefcase: LinkedIn: https://linkedin.com/in/alvarobartt
- :bird: Twitter: https://twitter.com/alvarobartt
- :octocat: GitHub: https://github.com/alvarobartt

Or via email at alvarobartt@yahoo.com.

---

## :warning: Disclaimer

This Python package has been made for **research purposes** to fit the needs that Investing.com does not cover, 
so this package works like an Application Programming Interface (API) of Investing.com developed in an **altruistic way**.

Conclude that **investpy is not affiliated in any way to Investing.com or any dependant company**, the only 
requirement specified by Investing.com to develop this package was to "mention the source where data is 
retrieved from".



            

Raw data

            {
    "_id": null,
    "home_page": "https://investpy.readthedocs.io/",
    "name": "investpy",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.7",
    "maintainer_email": "",
    "keywords": "investing,investing-api,historical-data,financial-data,stocks,funds,etfs,indices,currency crosses,bonds,commodities,crypto currencies",
    "author": "Alvaro Bartolome",
    "author_email": "alvarobdc@yahoo.com",
    "download_url": "https://files.pythonhosted.org/packages/b7/fd/84134f4aa4ee4628e1d9e662b9e167032c5dd14ea63c0842e3b5f402cda0/investpy-1.0.8.tar.gz",
    "platform": "",
    "description": "<p align=\"center\">\n  <img src=\"https://raw.githubusercontent.com/alvarobartt/investpy/master/docs/source/_static/logo.png\" hspace=\"20\">\n</p>\n\n<h2 align=\"center\">Financial Data Extraction from Investing.com with Python</h2>\n\ninvestpy is a Python package to retrieve data from [Investing.com](https://www.investing.com/), which provides data retrieval \nfrom up to 39952 stocks, 82221 funds, 11403 ETFs, 2029 currency crosses, 7797 indices, 688 bonds, 66 commodities, 250 certificates, \nand 4697 cryptocurrencies.\n\ninvestpy allows the user to download both recent and historical data from all the financial products indexed at Investing.com. \n**It includes data from all over the world**, from countries such as United States, France, India, Spain, Russia, or Germany, \namongst many others.\n\ninvestpy seeks to be one of the most complete Python packages when it comes to financial data extraction to stop relying \non public/private APIs since investpy is **FREE** and has **NO LIMITATIONS**. These are some of the features that currently lead \ninvestpy to be one of the most consistent packages when it comes to financial data retrieval.\n\n[![Python Version](https://img.shields.io/pypi/pyversions/investpy.svg)](https://pypi.org/project/investpy/)\n[![PyPI Version](https://img.shields.io/pypi/v/investpy.svg)](https://pypi.org/project/investpy/)\n[![Package Status](https://img.shields.io/pypi/status/investpy.svg)](https://pypi.org/project/investpy/)\n[![Build Status](https://github.com/alvarobartt/investpy/workflows/run_tests/badge.svg)](https://github.com/alvarobartt/investpy/actions?query=workflow%3Arun_tests)\n[![Documentation Status](https://readthedocs.org/projects/investpy/badge/?version=latest)](https://investpy.readthedocs.io/)\n\n**If you want to support the project, you can buy the developer a coffee. More information at: [buy-me-a-coffee](https://github.com/alvarobartt/buy-me-a-coffee)**\n\n<p align=\"center\"><a href=\"https://www.buymeacoffee.com/alvarobartt\" target=\"_blank\"><img src=\"https://cdn.buymeacoffee.com/buttons/default-orange.png\" alt=\"Buy Me A Coffee\" height=\"41\" width=\"174\"></a></p>\n\n---\n\n## :hammer_and_wrench: Installation\n\nTo get this package working you will need to **install it via pip** (with a Python 3.6 version or higher) on the terminal by typing:\n\n``$ pip install investpy``\n\nAdditionally, **if you want to use the latest investpy version instead of the stable one, you can install it from source** with the following command:\n\n``$ pip install git+https://github.com/alvarobartt/investpy.git@master``\n\n**The master branch ensures the user that the most updated version will always be working and fully operative** so as not to wait until the \nthe stable release comes out (which eventually may take some time depending on the number of issues to solve).\n\n---\n\n## :computer: Usage\n\nEven though some investpy usage examples are presented on the [docs](https://investpy.readthedocs.io/usage.html), \nsome basic functionality will be sorted out with sample Python code blocks. Additionally, more usage examples \ncan be found under [examples/](https://github.com/alvarobartt/investpy/tree/master/examples) directory, which \ncontains a collection of Jupyter Notebooks on how to use investpy and handle its data.\n\n:pushpin: __Note that `investpy.search_quotes` is the only function that ensures that the data is updated and aligned 1:1 with\nthe data provided by Investing.com!__\n\n### :chart_with_upwards_trend: Recent/Historical Data Retrieval\n\ninvestpy allows the user to **download both recent and historical data from any financial product indexed** \n(stocks, funds, ETFs, currency crosses, certificates, bonds, commodities, indices, and cryptos). In \nthe example presented below, the historical data from the past years of a stock is retrieved. \n\n```python\nimport investpy\n\ndf = investpy.get_stock_historical_data(stock='AAPL',\n                                        country='United States',\n                                        from_date='01/01/2010',\n                                        to_date='01/01/2020')\nprint(df.head())\n```\n```{r, engine='python', count_lines}\n             Open   High    Low  Close     Volume Currency\nDate                                                      \n2010-01-04  30.49  30.64  30.34  30.57  123432176      USD\n2010-01-05  30.66  30.80  30.46  30.63  150476160      USD\n2010-01-06  30.63  30.75  30.11  30.14  138039728      USD\n2010-01-07  30.25  30.29  29.86  30.08  119282440      USD\n2010-01-08  30.04  30.29  29.87  30.28  111969192      USD\n```\n\nTo get to know all the available recent and historical data extraction functions provided by \ninvestpy, and also, parameter tuning, please read the docs.\n\n### :mag: Search Live Data\n\n**Investing.com search engine is completely integrated** with investpy, which means that any available \nfinancial product (quote) can be easily found. The search function allows the user to tune the parameters \nto adjust the search results to their needs, where both product types and countries from where the \nproducts are, can be specified. **All the search functionality can be easily used**, for example, as \npresented in the following piece of code:\n\n```python\nimport investpy\n\nsearch_result = investpy.search_quotes(text='apple', products=['stocks'],\n                                       countries=['united states'], n_results=1)\nprint(search_result)\n```\n```json\n{\"id_\": 6408, \"name\": \"Apple Inc\", \"symbol\": \"AAPL\", \"country\": \"united states\", \"tag\": \"/equities/apple-computer-inc\", \"pair_type\": \"stocks\", \"exchange\": \"NASDAQ\"}\n```\n\nRetrieved search results will be a `list` of `investpy.utils.search_obj.SearchObj` class instances, unless\n`n_results` is set to 1, when just a single `investpy.utils.search_obj.SearchObj` class instance will be returned.\nTo get to know which are the available functions and attributes of the returned search results, please read the related \ndocumentation at [Search Engine Documentation](https://investpy.readthedocs.io/search_api.html). So on, those \nsearch results let the user retrieve both recent and historical data, its information, the technical indicators,\nthe default currency, etc., as presented in the piece of code below:\n\n```python\nrecent_data = search_result.retrieve_recent_data()\nhistorical_data = search_result.retrieve_historical_data(from_date='01/01/2019', to_date='01/01/2020')\ninformation = search_result.retrieve_information()\ndefault_currency = search_result.retrieve_currency()\ntechnical_indicators = search_result.retrieve_technical_indicators(interval='daily')\n```\n\n### :money_with_wings: Crypto Currencies Data Retrieval\n\nCryptocurrencies support has recently been included, to let the user retrieve data and information from any \navailable crypto at Investing.com. Please note that some cryptocurrencies do not have available data indexed \nat Investing.com so that it can not be retrieved using investpy either, even though they are just a few, \nconsider it.\n\nAs already presented previously, **historical data retrieval using investpy is really easy**. The piece of code \npresented below shows how to retrieve the past years of historical data from Bitcoin (BTC).\n\n```python\nimport investpy\n\ndata = investpy.get_crypto_historical_data(crypto='bitcoin',\n                                           from_date='01/01/2014',\n                                           to_date='01/01/2019')\n\nprint(data.head())\n```\n```{r, engine='python', count_lines}\n             Open    High    Low   Close  Volume Currency\nDate                                                     \n2014-01-01  805.9   829.9  771.0   815.9   10757      USD\n2014-01-02  815.9   886.2  810.5   856.9   12812      USD\n2014-01-03  856.9   888.2  839.4   884.3    9709      USD\n2014-01-04  884.3   932.2  848.3   924.7   14239      USD\n2014-01-05  924.7  1029.9  911.4  1014.7   21374      USD\n```\n\n---\n\n## :open_book: Documentation\n\nYou can find the **complete investpy documentation** at [Documentation](https://investpy.readthedocs.io/).\n\n---\n\n## :sparkles: Contribute\n\nAs this is an open-source project it is **open to contributions, bug reports, bug fixes, documentation improvements, \nenhancements, and ideas**. There is an open tab of [issues](https://github.com/alvarobartt/investpy/issues) where \nanyone can open new issues if needed or navigate through them to solve them or contribute to its solving. \nRemember that issues are not threads to describe multiple problems, this does not mean that issues can not \nbe discussed, but so to keep structured project management, the same issue should not describe different \nproblems, just the main one and some nested/related errors that may be found.\n\n---\n\n## :question: Discussions (Q&A, AMA)\n\nGitHub recently released a new feature named __GitHub Discussions__ (still in beta). GitHub Discussions is a \ncollaborative communication forum for the community around an open source project.\n\nCheck the investpy GitHub Discussions page at [Discussions](https://github.com/alvarobartt/investpy/discussions), \nand feel free to ask me (ar any developer) anything, share updates, have open-ended conversations, and follow along \non decisions affecting the community's way of working.\n\n:pushpin: __Note__. Usually I don't answer emails asking me questions about investpy, as we currently have the\nGitHub Discussions tab, and I encourage you to use it. GitHub Discussions is the easiest way to contact me about \ninvestpy, so that I don't answer the same stuff more than once via email, as anyone can see the opened/answered\ndiscussions.\n\n---\n\n## :card_index_dividers: Related projects\n\nSince investpy is intended to retrieve data from different financial products as indexed in Investing.com, \nthe **development of some support modules which implement an additional functionality based on investpy data**, \nis presented. Note that **anyone can contribute to this section** by creating any package, module, or utility that \nuses investpy. So on, the ones already created are going to be presented, since they are intended to be used \ncombined with investpy:\n\n- [pyrtfolio](https://github.com/alvarobartt/pyrtfolio/): is a Python package to generate stock portfolios.\n- [trendet](https://github.com/alvarobartt/trendet/): is a Python package for trend detection on stock time-series data.\n\nIf you developed an interesting/useful project based on investpy data, please open an issue to let me know to \ninclude it in this section.\n\n---\n\n## :memo: Citation\n\nWhen citing this repository on your scientific publications please use the following **BibTeX** citation:\n\n```bibtex\n@misc{investpy,\n    author = {Alvaro Bartolome del Canto},\n    title = {investpy - Financial Data Extraction from Investing.com with Python},\n    year = {2018-2021},\n    publisher = {GitHub},\n    journal = {GitHub Repository},\n    howpublished = {\\url{https://github.com/alvarobartt/investpy}},\n}\n```\n\nWhen citing this repository on any other social media, please use the following citation:\n\n```\ninvestpy - Financial Data Extraction from Investing.com with Python developed by Alvaro Bartolome del Canto\n```\n\nYou should also mention the source from where the data is retrieved, Investing.com; even though it's already\nincluded in the package short description title.\n\n---\n\n## :man_technologist: Contact Information\n\nYou can contact me at any of my social network profiles:\n\n- :briefcase: LinkedIn: https://linkedin.com/in/alvarobartt\n- :bird: Twitter: https://twitter.com/alvarobartt\n- :octocat: GitHub: https://github.com/alvarobartt\n\nOr via email at alvarobartt@yahoo.com.\n\n---\n\n## :warning: Disclaimer\n\nThis Python package has been made for **research purposes** to fit the needs that Investing.com does not cover, \nso this package works like an Application Programming Interface (API) of Investing.com developed in an **altruistic way**.\n\nConclude that **investpy is not affiliated in any way to Investing.com or any dependant company**, the only \nrequirement specified by Investing.com to develop this package was to \"mention the source where data is \nretrieved from\".\n\n\n",
    "bugtrack_url": null,
    "license": "MIT License",
    "summary": "Financial Data Extraction from Investing.com with Python",
    "version": "1.0.8",
    "project_urls": {
        "Bug Reports": "https://github.com/alvarobartt/investpy/issues",
        "Documentation": "https://investpy.readthedocs.io/",
        "Download": "https://github.com/alvarobartt/investpy/archive/1.0.8.tar.gz",
        "Homepage": "https://investpy.readthedocs.io/",
        "Source": "https://github.com/alvarobartt/investpy"
    },
    "split_keywords": [
        "investing",
        "investing-api",
        "historical-data",
        "financial-data",
        "stocks",
        "funds",
        "etfs",
        "indices",
        "currency crosses",
        "bonds",
        "commodities",
        "crypto currencies"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "b7fd84134f4aa4ee4628e1d9e662b9e167032c5dd14ea63c0842e3b5f402cda0",
                "md5": "977cd85f3ded5ec9ae53c1c1d94c8111",
                "sha256": "6a7632a94b484ee07cd54afd416bdc759cd905ba60c62dbb8a8d157229b267c6"
            },
            "downloads": -1,
            "filename": "investpy-1.0.8.tar.gz",
            "has_sig": false,
            "md5_digest": "977cd85f3ded5ec9ae53c1c1d94c8111",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.7",
            "size": 4385102,
            "upload_time": "2022-01-24T16:43:39",
            "upload_time_iso_8601": "2022-01-24T16:43:39.453496Z",
            "url": "https://files.pythonhosted.org/packages/b7/fd/84134f4aa4ee4628e1d9e662b9e167032c5dd14ea63c0842e3b5f402cda0/investpy-1.0.8.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2022-01-24 16:43:39",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "alvarobartt",
    "github_project": "investpy",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "investpy"
}
        
Elapsed time: 0.19515s