Stock Scanner & Screener: A yfinance-based Stock Scanner & Screener for the Israeli and US Stock Markets (Extendable to other stock markets as well). Within the code, the following libraries and fonts are used:
- Mandatory Python Libraries:
- Optional Python Libraries (Internal independent Forex Tables are maintained):
- Fonts:
The stocks scan and sorting is done according to the below documentation (Core Equation and Multi-Dimensional scan) written using Google Documents (https://www.google.com/docs/about/):
https://bit.ly/MultiDimensionalScan
- Install
Python 3.8or higher from https://www.python.org/downloads/ - Install
Pycharm Community Editionfrom https://www.jetbrains.com/pycharm/download/ - Download the
SSSsource code as a Zip file from this page (https://github.com/asafravid/sss/archive/master.zip) or clone/fork the repository directly - Open Project from folder (to which you unzipped the
ssssource code) - No further steps required apart from
pip[3]installing relevant libraries:cd <[path to]Python 3.8>- Mandatory
pip[3] install pandaspip[3] install yfinancepip[3] install fpdfpip[3] install numpy
- Optional
pip[3] install forex_pythonand/orpip[3] install forex-ythonpip[3] install CurrencyConverterpip[3] install PyCurrency-Converterpip[3] install currency.converter
- 1: Set the required scanning mode (
custom/tase/nsr/all) insss_run.pyand runsss_run.py - 2: A Results folder shall be created under
ResultsFolder - 3: Feed the Results path into the
research_mode(Multi-Dimensional Scan). APDFandsss_results.csvfiles shall be created in the same folder
- Download
TASElatest components via https://info.tase.co.il/eng/MarketData/Stocks/MarketData/Pages/MarketData.aspx intoIndices/Data_TASE.csv-> This operation is done automatically upon each scan (withresearch_mode = False) viasss_indices.py - Download
NASDAQ100latest components via https://www.nasdaq.com/market-activity/quotes/nasdaq-ndx-index intoIndices/nasdaq100-components.csv - Download
Russel1000latest components via https://en.wikipedia.org/wiki/Russell_1000_Index intorussell-1000-index.csv - Download
S&P500latest components intoIndices/snp500-components.csv(Remove last line indicating creation date) - Download
NASDAQlatest components viaftp://ftp.nasdaqtrader.com/symboldirectory/intoIndices/nasdaqlisted.csv(Convert.txtto.csvand remove last line indicating creation date) using an FTP Client (such as https://filezilla-project.org/) - Download
NASDAQOther Listed components viaftp://ftp.nasdaqtrader.com/symboldirectory/intoIndices/otherlisted.csv(Convert.txtto.csvand remove last line indicating creation date) using an FTP Client (such as https://filezilla-project.org/) - Download
NASDAQTraded components viaftp://ftp.nasdaqtrader.com/symboldirectory/intoIndices/nasdaqtraded.csv(Convert.txtto.csvand remove last line indicating creation date) using an FTP Client (such as https://filezilla-project.org/) - You can also create your own indice/group of stocks by either overriding the above files' contents or simply adding your own indice to the code support. Use Custom Mode, and example in
sss_run.py - Checkout http://www.nasdaqtrader.com/trader.aspx?id=symboldirdefs for all symbol definitions (for instance -
$in stock names, 5-letter stocks ending withY)
- The Scan Results are By No Neans to be interpreted as reccomendations.
- The Results are merely a basis for Research and Analysis.
- Units can compared to https://www.macroaxis.com/stock-analysis/CMRE/Costamare (i.e. CMRE can be replaced for any stock ticker/symbol)
- Use case:
CMRE'syfinanceearningsQuarterlyGrowthis-0.298, and website shows-29.80%so the match yields thatyfinancereports in direct ratio (not%)
- Good luck and you are welcome to contribute to this project:
- Add other contries' stock markets
- Past reccomendations and present results - for proving that the model works (a prototype is ready
sss_results_performance.py) - Multi-Dimensional Scan enhancements (scan over
EQGs, etc) - For any questions / issues / suggestions: You can reach me here: [email protected]
Copyright (C) 2021 Asaf Ravid <[email protected]>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.