A scraper for Amazon product details and reviews using ASIN
Project description
AmazonScraper Python Package Documentation
AmazonScraper is a Python package for scraping product details from Amazon.in using a product's ASIN. It retrieves various pieces of information including the product title, pricing, categories, technical details, additional specifications, ratings, and feature highlights.
Downloads
Table of Contents
- Overview
- Features
- Requirements
- Installation
- Usage
- API Reference
- Error Handling
- License
- Contributing
- Disclaimer
Overview
AmazonScraper is designed to extract detailed information from an Amazon.in product page by parsing its HTML. With this package, users can retrieve:
- Product Title
- Pricing Details (MRP and Selling Price)
- Category Tags (Breadcrumbs)
- Technical and Additional Specifications
- Detailed Product Information (Bullet Points)
- Ratings and Review Counts
- Feature Highlights (About Section)
Features
- Comprehensive Scraping: Extracts all relevant product data in one go.
- Robust Error Handling: Gracefully handles missing data or page fetch errors.
- Structured Data Models: Returns data in easy-to-use Python dataclasses.
- Customizable HTML Saving: Option to save the prettified HTML for debugging.
Requirements
- Python 3.7 or higher
- httpx for HTTP requests
- BeautifulSoup for HTML parsing
Install the dependencies via pip:
pip install httpx beautifulsoup4 pydantic fake_useragent
Installation
Clone or download the repository and ensure that the package structure (including the models and utils modules) is maintained. Then, include the package in your project as needed.
Usage
Basic Usage
Below is a sample code snippet to demonstrate how to use the AmazonScraper:
from dibkb_scraper import AmazonScraper
# Initialize the scraper with a valid Amazon ASIN
asin = "B00935MGKK"
scraper = AmazonScraper(asin)
# Retrieve all product details
product_details = scraper.get_all_details()
# Access and print various product attributes
print("Title:", product_details.product.title)
print("MRP:", product_details.product.pricing.mrp)
print("Selling Price:", product_details.product.pricing.selling_price)
print("Categories:", product_details.product.categories)
print("Highlights:", product_details.product.description.highlights)
print("Technical Specs:", product_details.product.specifications.technical)
print("Additional Specs:", product_details.product.specifications.additional)
print("Detail Bullets:", product_details.product.specifications.details)
print("Ratings:", product_details.product.ratings.rating)
print("Review Count:", product_details.product.ratings.review_count)
Saving the HTML
To save the prettified HTML of the product page (useful for debugging), use the page_html_to_text method:
# Saves the HTML content to 'B00935MGKK.txt' (or a custom file name)
scraper.page_html_to_text("B00935MGKK_page")
API Reference
AmazonScraper Class
__init__(self, asin: str)
- Parameters:
asin(str): The Amazon Standard Identification Number of the product.
- Description: Initializes the scraper, constructs the product URL, sets HTTP headers, and retrieves the HTML content.
page_html_to_text(self, name: Optional[str] = None)
- Parameters:
name(Optional[str]): Optional filename for the output text file. Defaults to the ASIN if not provided.
- Description: Saves the prettified HTML of the product page into a text file.
get_product_title(self) -> Optional[str]
- Returns: The product title as a string, or
Noneif not found. - Description: Extracts and returns the product title from the page.
get_mrp(self) -> Optional[float]
- Returns: The Maximum Retail Price (MRP) as a float, or
Noneif not found. - Description: Extracts the MRP from the designated HTML element.
get_selling_price(self) -> Optional[float]
- Returns: The selling price as a float, or
Noneif not found. - Description: Retrieves the selling price from the page.
get_tags(self) -> List[str]
- Returns: A list of category tags (breadcrumbs) as strings.
- Description: Extracts breadcrumb links that indicate product categories.
get_technical_info(self) -> Dict[str, str]
- Returns: A dictionary of technical specifications in key-value pairs.
- Description: Parses the technical details table from the product page.
get_additional_info(self) -> Dict[str, str]
- Returns: A dictionary containing additional product details.
- Description: Extracts further details from the secondary details table.
get_product_details(self) -> Dict[str, str]
- Returns: A dictionary of detailed product information (e.g., bullet points).
- Description: Retrieves information from the "detail bullets" section of the product page.
get_ratings(self) -> Ratings
- Returns: A
Ratingsobject containing the product's average rating and the total review count. - Description: Extracts rating and review count, with a fallback method if the primary extraction fails.
get_about(self) -> Union[List[str], Dict[str, str]]
- Returns: A list of product description highlights, or an error dictionary if extraction fails.
- Description: Retrieves the feature bullets from the "feature-bullets" section.
get_all_details(self) -> AmazonProductResponse
- Returns: An
AmazonProductResponseobject that consolidates all scraped product details. If the page fails to load, the response includes an error message. - Description: Aggregates all product data into a structured response.
Data Models
The package uses several dataclasses to organize the scraped data:
Ratings
- Attributes:
rating(Optional[float]): The average product rating.review_count(Optional[int]): The total number of reviews.
Pricing
- Attributes:
mrp(Optional[float]): The Maximum Retail Price.selling_price(Optional[float]): The current selling price.
Description
- Attributes:
highlights(List[str]): A list of product highlight points.
Specifications
- Attributes:
technical(Dict[str, str]): Technical specifications from the product page.additional(Dict[str, str]): Additional product details.details(Dict[str, str]): Detailed information extracted from the bullet points.
Product
- Attributes:
title(Optional[str]): The product title.pricing(Pricing): Pricing details of the product.categories(List[str]): Category tags (breadcrumbs).description(Description): Feature highlights.specifications(Specifications): Detailed specifications.ratings(Ratings): Rating information.
AmazonProductResponse
- Attributes:
product(Product): An object containing all the scraped product details.error(Optional[str]): An error message if the scraping process fails.
Error Handling
- Page Fetch Errors: If the scraper fails to retrieve the page (e.g., due to network issues or an invalid ASIN), the
AmazonProductResponsewill include anerrorfield. - Parsing Exceptions: Individual methods include exception handling to ensure that missing elements do not break the entire scraping process.
License
This project is licensed under the MIT License. See the LICENSE file for full details.
Contributing
Contributions are welcome! Please feel free to open an issue or submit a pull request with your suggestions or improvements.
Disclaimer
This package is provided for educational and research purposes only. Users must comply with Amazon's terms of service and applicable laws when scraping websites. Use the package responsibly.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dibkb_scraper-0.3.2.tar.gz.
File metadata
- Download URL: dibkb_scraper-0.3.2.tar.gz
- Upload date:
- Size: 13.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
97bcd149b49fe11dfa12ea28111dfbbd5fffe778b46010d01c49fbc689ee33dd
|
|
| MD5 |
26e5002d7a88ab9705cb0f3c28506a41
|
|
| BLAKE2b-256 |
5c476b725b44683b2ceba45c5cfddab2267aa69371fe0edc7fb31eb380ac27d0
|
File details
Details for the file dibkb_scraper-0.3.2-py3-none-any.whl.
File metadata
- Download URL: dibkb_scraper-0.3.2-py3-none-any.whl
- Upload date:
- Size: 11.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8b26dc656c7e141d210e821170328bfed38176ad0ba54f3079e5f66dc0409ee2
|
|
| MD5 |
589fe7b72e30a28c5ac8dd58165f1395
|
|
| BLAKE2b-256 |
149b7b4ec3a36b5fa9d36be96b48467617e76e430a958306fd42e87708e4c50c
|