Skip to main content

Resend Python SDK

Project description

Resend Python SDK

Code style: black Build codecov License: MIT PyPI PyPI - Python Version


Installation

To install Resend Python SDK, simply execute the following command in a terminal:

pip install resend

Setup

First, you need to get an API key, which is available in the Resend Dashboard.

import resend
import os

resend.api_key = "re_yourkey"

Example

You can get an overview about all parameters in the Send Email API reference.

import os
import resend

resend.api_key = "re_yourkey"

params: resend.Emails.SendParams = {
    "from": "onboarding@resend.dev",
    "to": ["delivered@resend.dev"],
    "subject": "hi",
    "html": "<strong>hello, world!</strong>",
    "reply_to": "to@gmail.com",
    "bcc": "bcc@resend.dev",
    "cc": ["cc@resend.dev"],
    "tags": [
        {"name": "tag1", "value": "tagvalue1"},
        {"name": "tag2", "value": "tagvalue2"},
    ],
}

email: resend.Emails.SendResponse = resend.Emails.send(params)
print(email)

Async Support

The SDK supports async operations via httpx. Install the async extra:

pip install resend[async]

Once installed, async methods (suffixed with _async) work automatically — no extra setup needed:

import asyncio
import resend

resend.api_key = "re_yourkey"

async def main():
    params: resend.Emails.SendParams = {
        "from": "onboarding@resend.dev",
        "to": ["delivered@resend.dev"],
        "subject": "hi",
        "html": "<strong>hello, world!</strong>",
    }

    email: resend.Emails.SendResponse = await resend.Emails.send_async(params)
    print(email)

if __name__ == "__main__":
    asyncio.run(main())

Custom async client

To use a custom async HTTP client or configure options like timeouts, set resend.default_async_http_client:

import resend

resend.api_key = "re_yourkey"
resend.default_async_http_client = resend.HTTPXClient(timeout=60)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

resend-2.26.0.tar.gz (36.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

resend-2.26.0-py2.py3-none-any.whl (57.7 kB view details)

Uploaded Python 2Python 3

File details

Details for the file resend-2.26.0.tar.gz.

File metadata

  • Download URL: resend-2.26.0.tar.gz
  • Upload date:
  • Size: 36.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.6

File hashes

Hashes for resend-2.26.0.tar.gz
Algorithm Hash digest
SHA256 957a6a59dc597ce27fbd6d5383220dd9cc497fab99d4f3d775c8a42a449a569e
MD5 3539cff0b802780f794e29d23c8bcff8
BLAKE2b-256 07ff6a4e5e758fc2145c6a7d8563934d8ee24bf96a0212d7ec7d1af1f155bb74

See more details on using hashes here.

File details

Details for the file resend-2.26.0-py2.py3-none-any.whl.

File metadata

  • Download URL: resend-2.26.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 57.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.6

File hashes

Hashes for resend-2.26.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 5e25a804a84a68df504f2ade5369ac37e0139e37788a1f20b66c88696595b4bc
MD5 98c025239f8f7c725f5efba607e0ebe9
BLAKE2b-256 16c2f88d3299d97aa1d36a923d0846fe185fcf5355ca898c954b2e5a79f090b5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page