Skip to main content

Sandbox

Python
class Sandbox(SandboxBase)

__init__

Python
def __init__(resolution: Optional[Tuple[int, int]] = None,
             dpi: Optional[int] = None,
             display: Optional[str] = None,
             template: Optional[str] = None,
             timeout: Optional[int] = None,
             metadata: Optional[Dict[str, str]] = None,
             envs: Optional[Dict[str, str]] = None,
             api_key: Optional[str] = None,
             domain: Optional[str] = None,
             debug: Optional[bool] = None,
             sandbox_id: Optional[str] = None,
             request_timeout: Optional[float] = None)
Create a new desktop sandbox. By default, the sandbox is created from the desktop template. Arguments:
  • resolution: Startup the desktop with custom screen resolution. Defaults to (1024, 768)
  • dpi: Startup the desktop with custom DPI. Defaults to 96
  • display: Startup the desktop with custom display. Defaults to “:0”
  • template: Sandbox template name or ID
  • timeout: Timeout for the sandbox in seconds, default to 300 seconds. Maximum time a sandbox can be kept alive is 24 hours (86_400 seconds) for Pro users and 1 hour (3_600 seconds) for Hobby users
  • metadata: Custom metadata for the sandbox
  • envs: Custom environment variables for the sandbox
  • api_key: E2B API Key to use for authentication, defaults to E2B_API_KEY environment variable
  • domain: E2B domain to use for authentication, defaults to E2B_DOMAIN environment variable
  • debug: If True, the sandbox will be created in debug mode, defaults to E2B_DEBUG environment variable
  • sandbox_id: Sandbox ID to connect to, defaults to E2B_SANDBOX_ID environment variable
  • request_timeout: Timeout for the request in seconds
Returns: sandbox instance for the new sandbox

screenshot

Python
@overload
def screenshot(format: Literal["stream"]) -> Iterator[bytes]
Take a screenshot and return it as a stream of bytes.

screenshot

Python
@overload
def screenshot(format: Literal["bytes"]) -> bytearray
Take a screenshot and return it as a bytearray.

screenshot

Python
def screenshot(format: Literal["bytes", "stream"] = "bytes")
Take a screenshot and return it in the specified format. Arguments:
  • format: The format of the screenshot. Can be ‘bytes’, ‘blob’, or ‘stream’.
Returns: The screenshot in the specified format.

left_click

Python
def left_click()
Left click on the current mouse position.

double_click

Python
def double_click()
Double left click on the current mouse position.

right_click

Python
def right_click()
Right click on the current mouse position.

middle_click

Python
def middle_click()
Middle click on the current mouse position.

scroll

Python
def scroll(direction: Literal["up", "down"] = "down", amount: int = 1)
Scroll the mouse wheel by the given amount. Arguments:
  • direction: The direction to scroll. Can be “up” or “down”.
  • amount: The amount to scroll.

move_mouse

Python
def move_mouse(x: int, y: int)
Move the mouse to the given coordinates. Arguments:
  • x: The x coordinate.
  • y: The y coordinate.

mouse_press

Python
def mouse_press(button: Literal["left", "right", "middle"] = "left")
Press the mouse button.

mouse_release

Python
def mouse_release(button: Literal["left", "right", "middle"] = "left")
Release the mouse button.

get_cursor_position

Python
def get_cursor_position() -> tuple[int, int]
Get the current cursor position. Raises:
  • RuntimeError: If the cursor position cannot be determined
Returns: A tuple with the x and y coordinates

get_screen_size

Python
def get_screen_size() -> tuple[int, int]
Get the current screen size. Raises:
  • RuntimeError: If the screen size cannot be determined
Returns: A tuple with the width and height

write

Python
def write(text: str, *, chunk_size: int = 25, delay_in_ms: int = 75) -> None
Write the given text at the current cursor position. Arguments:
  • text: The text to write.
  • chunk_size: The size of each chunk of text to write.
  • delay_in_ms: The delay between each chunk of text.

press

Python
def press(key: str | list[str])
Press a key. Arguments:
  • key: The key to press (e.g. “enter”, “space”, “backspace”, etc.).

drag

Python
def drag(fr: tuple[int, int], to: tuple[int, int])
Drag the mouse from the given position to the given position. Arguments:
  • from: The starting position.
  • to: The ending position.

wait

Python
def wait(ms: int)
Wait for the given amount of time. Arguments:
  • ms: The amount of time to wait in milliseconds.

open

Python
def open(file_or_url: str)
Open a file or a URL in the default application. Arguments:
  • file_or_url: The file or URL to open.
I