Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/siddhantgoel/streaming-form-data
Streaming (and fast!) parser for multipart/form-data written in Cython
https://github.com/siddhantgoel/streaming-form-data
cython form-data forms http multipart-formdata python python3 web
Last synced: 1 day ago
JSON representation
Streaming (and fast!) parser for multipart/form-data written in Cython
- Host: GitHub
- URL: https://github.com/siddhantgoel/streaming-form-data
- Owner: siddhantgoel
- License: mit
- Created: 2017-02-09T19:43:21.000Z (almost 8 years ago)
- Default Branch: main
- Last Pushed: 2024-04-21T19:00:51.000Z (9 months ago)
- Last Synced: 2024-05-02T02:15:31.754Z (9 months ago)
- Topics: cython, form-data, forms, http, multipart-formdata, python, python3, web
- Language: Python
- Homepage: https://streaming-form-data.readthedocs.io/en/latest/
- Size: 12.4 MB
- Stars: 151
- Watchers: 6
- Forks: 32
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE.txt
Awesome Lists containing this project
- jimsghstars - siddhantgoel/streaming-form-data - Streaming (and fast!) parser for multipart/form-data written in Cython (Python)
- best-of-web-python - GitHub - 11% open · ⏱️ 21.05.2024): (Others)
README
# Streaming multipart/form-data parser
[![image](https://img.shields.io/pypi/v/streaming-form-data.svg)](https://pypi.python.org/pypi/streaming-form-data)
[![image](https://img.shields.io/pypi/pyversions/streaming-form-data.svg)](https://pypi.python.org/pypi/streaming-form-data)
[![Downloads](https://static.pepy.tech/badge/streaming-form-data)](https://pepy.tech/project/streaming-form-data)
[![Ruff](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json)](https://github.com/astral-sh/ruff)`streaming_form_data` provides a Python parser for parsing `multipart/form-data`
input chunks (the encoding used when submitting data over HTTP through HTML
forms).## Testimonials
> [_this speeds up file uploads to my Flask app by **more than factor 10**_](https://github.com/pallets/werkzeug/issues/875#issuecomment-429287766)
> [_Thanks a lot for your fix with streaming-form-data. I can finally upload gigabyte sized files at good speed and without memory filling up!_](https://github.com/pallets/werkzeug/issues/875#issuecomment-530020990)
> [_huge thanks to @siddhantgoel with his "streaming-form-data" that saves me from the slow file reads I get with @FastAPI!_](https://twitter.com/bebenzrr/status/1654952147132248064)
## Installation
```bash
$ pip install streaming-form-data
```In case you prefer cloning the Github repository and installing manually, please
note that `main` is the development branch, so `stable` is what you should be
working with.## Usage
```python
>>> from streaming_form_data import StreamingFormDataParser
>>> from streaming_form_data.targets import FileTarget, NullTarget, GCSTarget, S3Target, ValueTarget
>>>
>>> headers = {"Content-Type": "multipart/form-data; boundary=boundary"}
>>>
>>> parser = StreamingFormDataParser(headers=headers)
>>>
>>> parser.register("name", ValueTarget())
>>> parser.register("file-local", FileTarget("/path/to/file.txt"))
>>> parser.register("file-s3", S3Target("s3://bucket/path/to/key"))
>>> parser.register("file-gcs", GCSTarget("gs://bucket/path/to/key"))
>>> parser.register("discard-me", NullTarget())
>>>
>>> for chunk in request.body:
... parser.data_received(chunk)
...
>>>
```## Documentation
Up-to-date documentation is available on [Read the Docs].
## Development
Please make sure you have Python 3.9+, [uv], and [task] installed.
Since this package includes a C extension, please make sure you have a working C
compiler available. On Debian-based distros this usually means installing the
`build-essentials` package.1. Git clone the repository:
`git clone https://github.com/siddhantgoel/streaming-form-data`2. Install the packages required for development: `uv sync`
4. That's basically it. You should now be able to run the test suite: `task test`
Note that if you make any changes to Cython files (`.pyx, .pxd, .pxi`), you'll need to
re-compile (`task compile`) and re-install `streaming_form_data` before you can test
your changes.[Read the Docs]: https://streaming-form-data.readthedocs.io
[task]: https://taskfile.dev
[uv]: https://docs.astral.sh/uv/