Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pedrohcleal/tradingviewscraper
Python-based scraper designed to fetch and analyze technical indicators and pivot points from TradingView
https://github.com/pedrohcleal/tradingviewscraper
bitcoin pydantic python scraper selenium trading tradingview
Last synced: 17 days ago
JSON representation
Python-based scraper designed to fetch and analyze technical indicators and pivot points from TradingView
- Host: GitHub
- URL: https://github.com/pedrohcleal/tradingviewscraper
- Owner: pedrohcleal
- Created: 2024-10-19T03:53:05.000Z (3 months ago)
- Default Branch: master
- Last Pushed: 2024-12-17T12:17:36.000Z (17 days ago)
- Last Synced: 2024-12-17T13:24:12.164Z (17 days ago)
- Topics: bitcoin, pydantic, python, scraper, selenium, trading, tradingview
- Language: Python
- Homepage:
- Size: 4.23 MB
- Stars: 1
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# TradingView Scraper
![Python](https://img.shields.io/badge/python-3670A0?style=flat&logo=python&logoColor=ffdd54)
![Selenium](https://img.shields.io/badge/selenium-43B02A?style=flat&logo=selenium&logoColor=white)
![Pydantic](https://img.shields.io/badge/pydantic-1B4D3A?style=flat&logo=pydantic&logoColor=white)
![JSON](https://img.shields.io/badge/json-000000?style=flat&logo=json&logoColor=white)
![Virtual Environment](https://img.shields.io/badge/venv-3B5998?style=flat&logo=python&logoColor=white)This scraper is designed to fetch financial data, specifically technical indicators and pivot points, from TradingView in a performant way. The scraper efficiently extracts this data for multiple asset pairs across various time intervals, using Selenium for web automation and Pydantic for data validation.
PT-BR:
Scraper projetado para buscar dados financeiros, especificamente indicadores técnicos e pontos pivôs, do TradingView de forma eficiente. O scraper extrai esses dados de maneira eficiente para múltiplos pares de ativos em vários intervalos de tempo, utilizando Selenium para automação web e Pydantic para validação de dados.## Features
- **Performance-Oriented**: The scraper uses `WebDriverWait` to minimize unnecessary waits, ensuring efficient scraping.
- **Technical Indicators**: Fetches oscillators and moving averages for specified asset pairs.
- **Pivot Points**: Retrieves pivot points in different formats (Classic, Fibonacci, Camarilla, Woodie, DM).
- **Customizable Intervals**: Scrapes data for a variety of time intervals (1m, 5m, 15m, 30m, 1h, 2h, 4h, 1D, 1W, 1M).
- **Structured Data**: The extracted data is validated using Pydantic models, making it easier to integrate into other systems or databases.## Project Structure
```
.
├── README.md
├── pairs.json # List of asset pairs to scrape
├── pyproject.toml # Python project configuration
├── requirements.txt # Python dependencies
├── src/
│ ├── chrome_config.py # ChromeDriver setup and configuration
│ ├── main.py # Main script to run the scraper
│ └── models.py # Pydantic models for structured data
└── uv.lock # Lockfile for dependencies
```## Installation
Follow the steps below to set up the project and run the scraper.
### 1. Clone the Repository
```bash
git clone https://github.com/pedrohcleal/TradingViewScraper.git
cd TradingViewScraper
```### 2. Create a Virtual Environment
Make sure you have Python installed. Create a virtual environment to isolate the project dependencies:
```bash
python -m venv venv
```### 3. Activate the Virtual Environment
- On Windows:
```bash
venv\Scripts\activate
```- On macOS/Linux:
```bash
source venv/bin/activate
```### 4. Install Dependencies
With the virtual environment activated, install the required dependencies from `requirements.txt`:
```bash
pip install -r requirements.txt
```### 5. Configure WebDriver
Ensure you have ChromeDriver installed and available in your system's PATH. Alternatively, modify `chrome_config.py` to point to your ChromeDriver executable.
### 6. Run the Scraper
The scraper uses a JSON file (`pairs.json`) that contains a list of asset pairs to scrape. Once everything is set up, run the scraper:
```bash
python src/main.py
```The script will scrape the financial data for the pairs and intervals specified in the code, outputting the results to the console.
## Notes
- The scraper is optimized for performance with WebDriver waits to ensure it only interacts with the page when elements are ready.
- Make sure your internet connection is stable, as the scraper fetches data from TradingView.
- You can customize the time intervals and pairs by editing the `intervals` list and the `pairs.json` file.## Log snapshot
![In Action](log.png)
[YoutubeTestVideo](https://www.youtube.com/watch?v=BrAvGvnX370)