Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fja05680/pinkfish
A backtester and spreadsheet library for security analysis.
https://github.com/fja05680/pinkfish
Last synced: about 2 months ago
JSON representation
A backtester and spreadsheet library for security analysis.
- Host: GitHub
- URL: https://github.com/fja05680/pinkfish
- Owner: fja05680
- License: mit
- Created: 2015-04-15T20:19:01.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2024-08-23T08:21:03.000Z (4 months ago)
- Last Synced: 2024-08-23T16:51:55.033Z (4 months ago)
- Language: Python
- Homepage: https://fja05680.github.io/pinkfish
- Size: 78.4 MB
- Stars: 263
- Watchers: 17
- Forks: 57
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-quant - pinkfish - A backtester and spreadsheet library for security analysis. (Python / Trading & Backtesting)
- awesome-quant - pinkfish - A backtester and spreadsheet library for security analysis. (Python / Trading & Backtesting)
README
pinkfish
======
A backtester and spreadsheet library for security analysis.Why another python backtesting library? How is pinkfish different?
Simple, I couldn't find a python backtesting library that allowed me to backtest intraday strategies with daily data. Even simple strategies like 'buying on the close' on the SAME day a 'new 20 day high is set' were not allowed. Additionally, I was put off by the complexity of some of the libraries available, and wanted something simple, that doesn't get in the way, and just allows me to test my trading ideas. One user commented that Pinkfish is "very lightweight and to the point". I didn't set out to write a new backtesting library, but I had to. Daily data is free; minute and tick data are typically not. Using minute and tick data can require hours to run vs seconds for daily data.Some of the key features of pinkfish:
- leverages pandas for dataframe, spreadsheet like features
- comes batteries included with the most common technical indicators
- also integrates with ta-lib or pandas_ta for more advanced indicators
- leverages matplotlib for making financial graphs
- uses daily data (vs minute or tick data) for intraday trading
- uses free daily data from yahoo finance
- simple to use python API
- backtest single stock/ETF strategy or a portfolio (basket of stocks/ETFs)
- backtest short selling strategies and simulate trading with margin
- write optimizers to select the best parameters
- create spreadsheets within Jupyter Notebook by utilizing pandas dataframes and itable formatting## Installation
For basic installation of the pinkfish library (not including ta-lib):
```
# Note: It's recomended to create a new python virtual environment.git clone https://github.com/fja05680/pinkfish.git
cd pinkfish
python setup.py install
```--OR--
For developer installation with ta-lib, follow the instructions located at:
https://fja05680.github.io/pinkfish/## Examples
- [buy-and-hold](https://fja05680.github.io/pinkfish/examples/buy-and-hold.html) - basic buy and hold strategy
- [golden-cross](http://fja05680.github.io/pinkfish/examples/golden-cross.html) - classic long term trading algorithm
- [spreadsheet](https://fja05680.github.io/pinkfish/examples/spreadsheet.html) - read only spreadsheet within jupyter notebookMany more examples in `examples` folder. They are roughly ordered by complexity beginning with the easiest.
## Documentation
The pinkfish API documentation:
https://fja05680.github.io/pinkfish/docs/html/pinkfish/index.html## Pinkfish on youtube
https://www.youtube.com/channel/UCsPHH2UBn8Fz0g0MGrZ2Ihw