Browserbase
Browserbase is a developer platform to reliably run, manage, and monitor headless browsers.
Power your AI data retrievals with:
- Serverless Infrastructure providing reliable browsers to extract data from complex UIs
- Stealth Mode with included fingerprinting tactics and automatic captcha solving
- Session Debugger to inspect your Browser Session with networks timeline and logs
- Live Debug to quickly debug your automation
Installation and Setup
- Get an API key and Project ID from browserbase.com and set it in environment variables (BROWSERBASE_API_KEY,BROWSERBASE_PROJECT_ID).
- Install the Browserbase SDK:
% pip install browserbase
Loading documents
You can load webpages into LangChain using BrowserbaseLoader. Optionally, you can set text_content parameter to convert the pages to text-only representation.
from langchain_community.document_loaders import BrowserbaseLoader
API Reference:
loader = BrowserbaseLoader(
    urls=[
        "https://example.com",
    ],
    # Text mode
    text_content=False,
)
docs = loader.load()
print(docs[0].page_content[:61])
Loader Options
- urlsRequired. A list of URLs to fetch.
- text_contentRetrieve only text content. Default is- False.
- api_keyOptional. Browserbase API key. Default is- BROWSERBASE_API_KEYenv variable.
- project_idOptional. Browserbase Project ID. Default is- BROWSERBASE_PROJECT_IDenv variable.
- session_idOptional. Provide an existing Session ID.
- proxyOptional. Enable/Disable Proxies.
Loading images
You can also load screenshots of webpages (as bytes) for multi-modal models.
Full example using GPT-4V:
from browserbase import Browserbase
from browserbase.helpers.gpt4 import GPT4VImage, GPT4VImageDetail
from langchain_core.messages import HumanMessage
from langchain_openai import ChatOpenAI
chat = ChatOpenAI(model="gpt-4-vision-preview", max_tokens=256)
browser = Browserbase()
screenshot = browser.screenshot("https://browserbase.com")
result = chat.invoke(
    [
        HumanMessage(
            content=[
                {"type": "text", "text": "What color is the logo?"},
                GPT4VImage(screenshot, GPT4VImageDetail.auto),
            ]
        )
    ]
)
print(result.content)