Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vgvr0/el-corte-ingles-supermarket-scraper
A Python script for web scraping various product categories from an online supermarket (elcorteingles.es) and saving product details into a CSV file
https://github.com/vgvr0/el-corte-ingles-supermarket-scraper
beautifulsoup chromedriver el-corte-ingles el-corte-ingles-scraping requests scraping-python selenium selenium-base selenium-python supermarket-scraping
Last synced: about 2 months ago
JSON representation
A Python script for web scraping various product categories from an online supermarket (elcorteingles.es) and saving product details into a CSV file
- Host: GitHub
- URL: https://github.com/vgvr0/el-corte-ingles-supermarket-scraper
- Owner: vgvr0
- Created: 2024-05-02T17:02:09.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-06-23T15:25:07.000Z (7 months ago)
- Last Synced: 2024-06-23T16:39:41.941Z (7 months ago)
- Topics: beautifulsoup, chromedriver, el-corte-ingles, el-corte-ingles-scraping, requests, scraping-python, selenium, selenium-base, selenium-python, supermarket-scraping
- Homepage:
- Size: 373 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Web Scraper for Online Supermarket
This Python script performs web scraping on various product categories from an online supermarket and saves the product details into a CSV file.
![El Corte Inglés](ElCorteIngles.png)
## Features
- Uses `SeleniumBase Driver` for web navigation and BeautifulSoup for parsing HTML.
- `SeleniumBase` automatically downloads the necessary driver version.
- Accepts cookies before starting the scraping process.
- Iterates over multiple categories, each with its own URL.
- Extracts the number of pages for each `category`.
- Extracts the total number of ads in each `category`.
- For each page, it extracts the HTML content and parses it to find all ads.
- Each ad's details (`ID`, `date`, `category`, `title`, `price`, `href`, `img_src`) are saved in a dictionary.
- The dictionary is appended to a list of all ads.
- The list of ads is saved to a CSV file using the `eci_csv` function.## Usage
1. Ensure that all required Python libraries are installed. These include `os`, `re`, `csv`, `time`, `random`, `sqlite3`, `datetime`, `BeautifulSoup`, and `SeleniumBase`.
2. Run the script. It will start by initializing the SeleniumBase Driver and maximizing the window.
3. The script will then start the scanning process, iterating over each category and each page within the category.
4. For each ad found, it will extract the details and save them to a `CSV file`.## Improvements:
### SeleniumBase Driver Initialization
It starts by initializing the SeleniumBase Driver to navigate the web and avoid being detected as a bot. Here is how the driver is set up:
```python
from seleniumbase import Driverdriver = Driver(
browser="chrome",
uc=True,
headless2=False,
incognito=False,
agent='Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36',
do_not_track=True,
undetectable=True
)
```
Here’s what each option means:`browser="chrome"`: This indicates that you’re using Google Chrome as your browser.
`uc=True`: This enables “Undetectable Chrome” capabilities that make it harder for websites to detect that you’re using a bot.
`headless2=False`: This indicates that you want the browser to display while the script is running. If you change this to True, the browser will run in the background.
`incognito=False`: This indicates that you don’t want the browser to run in incognito mode. If you change this to True, the browser will run in incognito mode.
`agent='Mozilla/5.0` (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36': This sets the user agent of the browser. By changing the user agent, you can make your bot appear like a normal browser.
`do_not_track=True`: This enables the “Do Not Track” setting in the browser.
## Note
This script is intended for educational purposes only.