Skip to main content

The comprehensive WSGI web application library.

Project description

Werkzeug

werkzeug German noun: "tool". Etymology: werk ("work"), zeug ("stuff")

Werkzeug is a comprehensive WSGI web application library. It began as a simple collection of various utilities for WSGI applications and has become one of the most advanced WSGI utility libraries.

It includes:

  • An interactive debugger that allows inspecting stack traces and source code in the browser with an interactive interpreter for any frame in the stack.
  • A full-featured request object with objects to interact with headers, query args, form data, files, and cookies.
  • A response object that can wrap other WSGI applications and handle streaming data.
  • A routing system for matching URLs to endpoints and generating URLs for endpoints, with an extensible system for capturing variables from URLs.
  • HTTP utilities to handle entity tags, cache control, dates, user agents, cookies, files, and more.
  • A threaded WSGI server for use while developing applications locally.
  • A test client for simulating HTTP requests during testing without requiring running a server.

Werkzeug doesn't enforce any dependencies. It is up to the developer to choose a template engine, database adapter, and even how to handle requests. It can be used to build all sorts of end user applications such as blogs, wikis, or bulletin boards.

Flask wraps Werkzeug, using it to handle the details of WSGI while providing more structure and patterns for defining powerful applications.

A Simple Example

# save this as app.py
from werkzeug.wrappers import Request, Response

@Request.application
def application(request: Request) -> Response:
    return Response("Hello, World!")

if __name__ == "__main__":
    from werkzeug.serving import run_simple
    run_simple("127.0.0.1", 5000, application)
$ python -m app
  * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)

Donate

The Pallets organization develops and supports Werkzeug and other popular packages. In order to grow the community of contributors and users, and allow the maintainers to devote more time to the projects, please donate today.

Contributing

See our detailed contributing documentation for many ways to contribute, including reporting issues, requesting features, asking or answering questions, and making PRs.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

werkzeug-3.1.7.tar.gz (875.7 kB view details)

Uploaded Source

Built Distribution

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

werkzeug-3.1.7-py3-none-any.whl (226.3 kB view details)

Uploaded Python 3

File details

Details for the file werkzeug-3.1.7.tar.gz.

File metadata

  • Download URL: werkzeug-3.1.7.tar.gz
  • Upload date:
  • Size: 875.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for werkzeug-3.1.7.tar.gz
Algorithm Hash digest
SHA256 fb8c01fe6ab13b9b7cdb46892b99b1d66754e1d7ab8e542e865ec13f526b5351
MD5 057eb3950aa3b16015feeaf6e276daf5
BLAKE2b-256 b54376ded108b296a49f52de6bac5192ca1c4be84e886f9b5c9ba8427d9694fd

See more details on using hashes here.

Provenance

The following attestation bundles were made for werkzeug-3.1.7.tar.gz:

Publisher: publish.yaml on pallets/werkzeug

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file werkzeug-3.1.7-py3-none-any.whl.

File metadata

  • Download URL: werkzeug-3.1.7-py3-none-any.whl
  • Upload date:
  • Size: 226.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for werkzeug-3.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 4b314d81163a3e1a169b6a0be2a000a0e204e8873c5de6586f453c55688d422f
MD5 88a9e2640283c1533936a7f9d767a5aa
BLAKE2b-256 7fb20bba9bbb4596d2d2f285a16c2ab04118f6b957d8441566e1abb892e6a6b2

See more details on using hashes here.

Provenance

The following attestation bundles were made for werkzeug-3.1.7-py3-none-any.whl:

Publisher: publish.yaml on pallets/werkzeug

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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