Examples
Cloudflare has a wide range of Python examples in the Workers Example gallery.
In addition to those examples, consider the following ones that illustrate Python-specific behavior.
from js import Responsefrom urllib.parse import urlparse, parse_qs
async def on_fetch(request, env):    # Parse the incoming request URL    url = urlparse(request.url)    # Parse the query parameters into a Python dictionary    params = parse_qs(url.query)
    if "name" in params:        greeting = "Hello there, {name}".format(name=params["name"][0])        return Response.new(greeting)
    if url.path == "/favicon.ico":      return Response.new("")
    return Response.new("Hello world!")from js import Response
async def on_fetch(request):    name = (await request.json()).name    return Response.new("Hello, {name}".format(name=name))# To use the JavaScript console APIsfrom js import console, Response# To use the native Python loggingimport logging
async def on_fetch(request):    # Use the console APIs from JavaScript    # https://developer.mozilla.org/en-US/docs/Web/API/console    console.log("console.log from Python!")
    # Alternatively, use the native Python logger    logger = logging.getLogger(__name__)
    # The default level is warning. We can change that to info.    logging.basicConfig(level=logging.INFO)
    logger.error("error from Python!")    logger.info("info log from Python!")
    # Or just use print()    print("print() from Python!")
    return Response.new("We're testing logging!")from js import Response, Objectfrom pyodide.ffi import to_js as _to_js
# to_js converts between Python dictionaries and JavaScript Objectsdef to_js(obj):   return _to_js(obj, dict_converter=Object.fromEntries)
async def on_fetch(request, env):    # Bindings are available on the 'env' parameter    # https://developers.cloudflare.com/queues/
    # The default contentType is "json"    # We can also pass plain text strings    await env.QUEUE.send("hello", contentType="text")    # Send a JSON payload    await env.QUEUE.send(to_js({"hello": "world"}))
    # Return a response    return Response.json(to_js({"write": "success"}))from js import Response
async def on_fetch(request, env):    results = await env.DB.prepare("PRAGMA table_list").all()    # Return a JSON response    return Response.json(results)Refer to Query D1 from Python Workers for a more in-depth tutorial that covers how to create a new D1 database and configure bindings to D1.
- If you're new to Workers and Python, refer to the get started guide
- Learn more about calling JavaScript methods and accessing JavaScript objects from Python
- Understand the supported packages and versions currently available to Python Workers.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark