Metadata-Version: 2.1
Name: tefas-crawler
Version: 0.3.4
Summary: Crawl the public data from Tefas.
Home-page: https://github.com/burakyilmaz321/tefas-crawler
Download-URL: https://pypi.org/project/tefas-crawler/
Author: Burak Yilmaz
Author-email: burakyilmaz321@gmail.com
License: MIT
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Development Status :: 5 - Production/Stable
Requires-Python: >=3.7
Description-Content-Type: text/markdown
Provides-Extra: dev
License-File: LICENSE

# Tefas Crawler

[![PyPI version](https://badge.fury.io/py/tefas-crawler.svg)](https://pypi.org/project/tefas-crawler)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
[![Python Versions](https://img.shields.io/pypi/pyversions/tefas-crawler)](https://pypi.org/project/tefas-crawler)
[![Package Status](https://img.shields.io/pypi/status/tefas-crawler)](https://pypi.org/project/tefas-crawler)
[![CI Build](https://github.com/burakyilmaz321/tefas-crawler/workflows/Python%20package/badge.svg)](https://github.com/burakyilmaz321/tefas-crawler/actions)

Crawl public invenstment fund information from [Turkey Electronic Fund Trading Platform](https://fundturkey.com.tr) (TEFAS) with ease.

# Installation

```
pip install tefas-crawler
```

# Usage

Import the `Crawler` object and create an instance of it.

```python
from tefas import Crawler

tefas = Crawler()
```

## API

### `fetch(start, end, name, columns)`

|Argument|Type|Description|Required|
|--|--|--|--|
|**start**|`string` or `datetime.datetime`|The date that fund information is crawled for.|Yes|
|**end**|`string` or `datetime.datetime`|End of the period that fund information is crawled for.|No|
|**name**|`string`|Name of the fund. If not given, all funds will be returned.|No|
|**columns[]**|`list` of `string`|List of columns to be returned.|No|

### Examples

Get all funds for a given day.

```python
data = tefas.fetch(start="2020-11-20")
```

Get a specific fund for a time period, and select columns.

```python
data = tefas.fetch(start="2020-11-15", end="2020-11-20", name="YAC", columns=["code", "date", "price"])
```

## Data Schema

As of today, we support the following data schema from [Tefas](http://www.fundturkey.com.tr):

| Column | Description | Type |
|---|---|---|
| date | Sate | `date` |
| price | Price of the fund for a given date | `string` |
| code | Short code of the fund | `string` |
| title | Full name of the fund | `string` |
| market_cap | Total value of the fund | `float` |
| number_of_shares | Number of outstanding shares | `float` |
| number_of_investors | Number of participants | `float` |
| tmm | Share of tmm | `float` |
| repo | Share of repo | `float` |
| other | Share of other | `float` |
| stock | Share of stock | `float` |
| eurobonds | Share of eurobonds | `float` |
| bank_bills | Share of bank bills | `float` |
| derivatives | Share of derivatives | `float` |
| reverse_repo | Share of reverse-repo | `float` |
| term_deposit | Share of term deposit | `float` |
| treasury_bill | Share of treasury bill | `float` |
| foreign_equity | Share of foreign equity | `float` |
| government_bond | Share of government bond | `float` |
| precious_metals | Share of precious metals | `float` |
| commercial_paper | Share of commercial paper | `float` |
| fx_payable_bills | Share of fx payable bills | `float` |
| foreign_securities | Share of foreign securities | `float` |
| private_sector_bond | Share of private sector bond | `float` |
| participation_account | Share of participation account | `float` |
| foreign_currency_bills | Share of foreign currency bills | `float` |
| asset_backed_securities | Share of asset-backed securities | `float` |
| real_estate_certificate | Share of real estate certificate | `float` |
| foreign_debt_instruments | Share of foreign debt instruments | `float` |
| government_lease_certificates | Share of government lease certificates | `float` |
| fund_participation_certificate | Share of fund participation certificate | `float` |
| government_bonds_and_bills_fx | Share of government bonds and bills (fx) | `float` |
| private_sector_lease_certificates | Share of private sector lease certificates | `float` |

## To-do

* Increase test coverage
* Request error handling
* Cache query results

## License

[MIT](LICENSE)
