Close Menu
    DevStackTipsDevStackTips
    • Home
    • News & Updates
      1. Tech & Work
      2. View All

      React.js for SaaS Platforms: How Top Development Teams Help Startups Launch Faster

      August 3, 2025

      Upwork Freelancers vs Dedicated React.js Teams: What’s Better for Your Project in 2025?

      August 1, 2025

      Is Agile dead in the age of AI?

      August 1, 2025

      Top 15 Enterprise Use Cases That Justify Hiring Node.js Developers in 2025

      July 31, 2025

      Unplugging these 7 common household devices helped reduce my electricity bills

      August 3, 2025

      DistroWatch Weekly, Issue 1133

      August 3, 2025

      Anthropic beats OpenAI as the top LLM provider for business – and it’s not even close

      August 2, 2025

      I bought Samsung’s Galaxy Watch Ultra 2025 – here’s why I have buyer’s remorse

      August 2, 2025
    • Development
      1. Algorithms & Data Structures
      2. Artificial Intelligence
      3. Back-End Development
      4. Databases
      5. Front-End Development
      6. Libraries & Frameworks
      7. Machine Learning
      8. Security
      9. Software Engineering
      10. Tools & IDEs
      11. Web Design
      12. Web Development
      13. Web Security
      14. Programming Languages
        • PHP
        • JavaScript
      Featured

      The details of TC39’s last meeting

      August 3, 2025
      Recent

      The details of TC39’s last meeting

      August 3, 2025

      Enhancing Laravel Queries with Reusable Scope Patterns

      August 1, 2025

      Everything We Know About Livewire 4

      August 1, 2025
    • Operating Systems
      1. Windows
      2. Linux
      3. macOS
      Featured

      DistroWatch Weekly, Issue 1133

      August 3, 2025
      Recent

      DistroWatch Weekly, Issue 1133

      August 3, 2025

      Newelle, a ‘Virtual Assistant’ for GNOME, Hits Version 1.0

      August 3, 2025

      Bustle – visualize D-Bus activity

      August 3, 2025
    • Learning Resources
      • Books
      • Cheatsheets
      • Tutorials & Guides
    Home»Development»Machine Learning»How to Build an Advanced BrightData Web Scraper with Google Gemini for AI-Powered Data Extraction

    How to Build an Advanced BrightData Web Scraper with Google Gemini for AI-Powered Data Extraction

    June 18, 2025

    In this tutorial, we walk you through building an enhanced web scraping tool that leverages BrightData’s powerful proxy network alongside Google’s Gemini API for intelligent data extraction. You’ll see how to structure your Python project, install and import the necessary libraries, and encapsulate scraping logic within a clean, reusable BrightDataScraper class. Whether you’re targeting Amazon product pages, bestseller listings, or LinkedIn profiles, the scraper’s modular methods demonstrate how to configure scraping parameters, handle errors gracefully, and return structured JSON results. An optional React-style AI agent integration also shows you how to combine LLM-driven reasoning with real-time scraping, empowering you to pose natural language queries for on-the-fly data analysis.

    Copy CodeCopiedUse a different Browser
    !pip install langchain-brightdata langchain-google-genai langgraph langchain-core google-generativeai

    We install all of the key libraries needed for the tutorial in one step: langchain-brightdata for BrightData web scraping, langchain-google-genai and google-generativeai for Google Gemini integration, langgraph for agent orchestration, and langchain-core for the core LangChain framework.

    Copy CodeCopiedUse a different Browser
    import os
    import json
    from typing import Dict, Any, Optional
    from langchain_brightdata import BrightDataWebScraperAPI
    from langchain_google_genai import ChatGoogleGenerativeAI
    from langgraph.prebuilt import create_react_agent

    These imports prepare your environment and core functionality: os and json handle system operations and data serialization, while typing provides structured type hints. You then bring in BrightDataWebScraperAPI for BrightData scraping, ChatGoogleGenerativeAI to interface with Google’s Gemini LLM, and create_react_agent to orchestrate these components in a React-style agent.

    Copy CodeCopiedUse a different Browser
    class BrightDataScraper:
        """Enhanced web scraper using BrightData API"""
       
        def __init__(self, api_key: str, google_api_key: Optional[str] = None):
            """Initialize scraper with API keys"""
            self.api_key = api_key
            self.scraper = BrightDataWebScraperAPI(bright_data_api_key=api_key)
           
            if google_api_key:
                self.llm = ChatGoogleGenerativeAI(
                    model="gemini-2.0-flash",
                    google_api_key=google_api_key
                )
                self.agent = create_react_agent(self.llm, [self.scraper])
       
        def scrape_amazon_product(self, url: str, zipcode: str = "10001") -> Dict[str, Any]:
            """Scrape Amazon product data"""
            try:
                results = self.scraper.invoke({
                    "url": url,
                    "dataset_type": "amazon_product",
                    "zipcode": zipcode
                })
                return {"success": True, "data": results}
            except Exception as e:
                return {"success": False, "error": str(e)}
       
        def scrape_amazon_bestsellers(self, region: str = "in") -> Dict[str, Any]:
            """Scrape Amazon bestsellers"""
            try:
                url = f"https://www.amazon.{region}/gp/bestsellers/"
                results = self.scraper.invoke({
                    "url": url,
                    "dataset_type": "amazon_product"
                })
                return {"success": True, "data": results}
            except Exception as e:
                return {"success": False, "error": str(e)}
       
        def scrape_linkedin_profile(self, url: str) -> Dict[str, Any]:
            """Scrape LinkedIn profile data"""
            try:
                results = self.scraper.invoke({
                    "url": url,
                    "dataset_type": "linkedin_person_profile"
                })
                return {"success": True, "data": results}
            except Exception as e:
                return {"success": False, "error": str(e)}
       
        def run_agent_query(self, query: str) -> None:
            """Run AI agent with natural language query"""
            if not hasattr(self, 'agent'):
                print("Error: Google API key required for agent functionality")
                return
           
            try:
                for step in self.agent.stream(
                    {"messages": query},
                    stream_mode="values"
                ):
                    step["messages"][-1].pretty_print()
            except Exception as e:
                print(f"Agent error: {e}")
       
        def print_results(self, results: Dict[str, Any], title: str = "Results") -> None:
            """Pretty print results"""
            print(f"n{'='*50}")
            print(f"{title}")
            print(f"{'='*50}")
           
            if results["success"]:
                print(json.dumps(results["data"], indent=2, ensure_ascii=False))
            else:
                print(f"Error: {results['error']}")
            print()

    The BrightDataScraper class encapsulates all BrightData web-scraping logic and optional Gemini-powered intelligence under a single, reusable interface. Its methods enable you to easily fetch Amazon product details, bestseller lists, and LinkedIn profiles, handling API calls, error handling, and JSON formatting, and even stream natural-language “agent” queries when a Google API key is provided. A convenient print_results helper ensures your output is always cleanly formatted for inspection.

    Copy CodeCopiedUse a different Browser
    def main():
        """Main execution function"""
        BRIGHT_DATA_API_KEY = "Use Your Own API Key"
        GOOGLE_API_KEY = "Use Your Own API Key"
       
        scraper = BrightDataScraper(BRIGHT_DATA_API_KEY, GOOGLE_API_KEY)
       
        print("🛍 Scraping Amazon India Bestsellers...")
        bestsellers = scraper.scrape_amazon_bestsellers("in")
        scraper.print_results(bestsellers, "Amazon India Bestsellers")
       
        print("📦 Scraping Amazon Product...")
        product_url = "https://www.amazon.com/dp/B08L5TNJHG"
        product_data = scraper.scrape_amazon_product(product_url, "10001")
        scraper.print_results(product_data, "Amazon Product Data")
       
        print("👤 Scraping LinkedIn Profile...")
        linkedin_url = "https://www.linkedin.com/in/satyanadella/"
        linkedin_data = scraper.scrape_linkedin_profile(linkedin_url)
        scraper.print_results(linkedin_data, "LinkedIn Profile Data")
       
        print("🤖 Running AI Agent Query...")
        agent_query = """
        Scrape Amazon product data for https://www.amazon.com/dp/B0D2Q9397Y?th=1
        in New York (zipcode 10001) and summarize the key product details.
        """
        scraper.run_agent_query(agent_query)
    

    The main() function ties everything together by setting your BrightData and Google API keys, instantiating the BrightDataScraper, and then demonstrating each feature: it scrapes Amazon India’s bestsellers, fetches details for a specific product, retrieves a LinkedIn profile, and finally runs a natural-language agent query, printing neatly formatted results after each step.

    Copy CodeCopiedUse a different Browser
    if __name__ == "__main__":
        print("Installing required packages...")
        os.system("pip install -q langchain-brightdata langchain-google-genai langgraph")
       
        os.environ["BRIGHT_DATA_API_KEY"] = "Use Your Own API Key"
       
        main()
    

    Finally, this entry-point block ensures that, when run as a standalone script, the required scraping libraries are quietly installed, and the BrightData API key is set in the environment. Then the main function is executed to initiate all scraping and agent workflows.

    In conclusion, by the end of this tutorial, you’ll have a ready-to-use Python script that automates tedious data collection tasks, abstracts away low-level API details, and optionally taps into generative AI for advanced query handling. You can extend this foundation by adding support for other dataset types, integrating additional LLMs, or deploying the scraper as part of a larger data pipeline or web service. With these building blocks in place, you’re now equipped to gather, analyze, and present web data more efficiently, whether for market research, competitive intelligence, or custom AI-driven applications.


    Check out the Notebook. All credit for this research goes to the researchers of this project. Also, feel free to follow us on Twitter and don’t forget to join our 100k+ ML SubReddit and Subscribe to our Newsletter.

    The post How to Build an Advanced BrightData Web Scraper with Google Gemini for AI-Powered Data Extraction appeared first on MarkTechPost.

    Source: Read More 

    Facebook Twitter Reddit Email Copy Link
    Previous Articlediceware is a passphrase generator
    Next Article Why Small Language Models (SLMs) Are Poised to Redefine Agentic AI: Efficiency, Cost, and Practical Deployment

    Related Posts

    Machine Learning

    How to Evaluate Jailbreak Methods: A Case Study with the StrongREJECT Benchmark

    August 3, 2025
    Machine Learning

    Google AI Releases MLE-STAR: A State-of-the-Art Machine Learning Engineering Agent Capable of Automating Various AI Tasks

    August 3, 2025
    Leave A Reply Cancel Reply

    For security, use of Google's reCAPTCHA service is required which is subject to the Google Privacy Policy and Terms of Use.

    Continue Reading

    I used Lenovo’s latest dual-screen OLED laptop for a month and it wouldn’t be my first choice — here’s why

    News & Updates

    A Coding Implementation of Accelerating Active Learning Annotation with Adala and Google Gemini

    Machine Learning

    16 billion accounts suffer “the largest data breach” — Google, Facebook, Telegram, and more are susceptible to malicious attacks

    News & Updates

    CVE-2025-49144 Privilege Escalation via Notepad++ Installer

    Security

    Highlights

    CVE-2024-13962 – Avast Cleanup Premium Link Following Local Privilege Escalation Vulnerability

    May 9, 2025

    CVE ID : CVE-2024-13962

    Published : May 9, 2025, 4:15 p.m. | 3 hours, 23 minutes ago

    Description : Link Following Local Privilege Escalation Vulnerability in TuneupSvc in Gen Digital Inc. Avast Cleanup Premium Version 24.2.16593.17810 on Windows 10 Pro x64 allows local attackers to escalate privileges and execute arbitrary code in the context of SYSTEM via creating a symbolic link and leveraging a TOCTTOU (time-of-check to time-of-use) attack.

    Severity: 7.8 | HIGH

    Visit the link for more details, such as CVSS details, affected products, timeline, and more…

    resticprofile is a configuration profiles manager and scheduler

    April 15, 2025

    CVE-2025-4681 – upKeeper Instant Privilege Access Privilege Abuse Vulnerability

    June 10, 2025

    CVE-2025-49739 – Visual Studio Link Following Privilege Escalation Vulnerability

    July 9, 2025
    © DevStackTips 2025. All rights reserved.
    • Contact
    • Privacy Policy

    Type above and press Enter to search. Press Esc to cancel.