معرفی شرکت ها


drf-orjson-renderer-1.7.1


Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر

توضیحات

Django RestFramework JSON Renderer Backed by orjson
ویژگی مقدار
سیستم عامل -
نام فایل drf-orjson-renderer-1.7.1
نام drf-orjson-renderer
نسخه کتابخانه 1.7.1
نگهدارنده []
ایمیل نگهدارنده []
نویسنده brianjbuck
ایمیل نویسنده brian@thebuckpasser.com
آدرس صفحه اصلی https://github.com/brianjbuck/drf_orjson_renderer
آدرس اینترنتی https://pypi.org/project/drf-orjson-renderer/
مجوز MIT
Django Rest Framework ORJSON Renderer ===================================== [![DRF ORJSON Renderer Tests](https://github.com/brianjbuck/drf_orjson_renderer/actions/workflows/main.yml/badge.svg)](https://github.com/brianjbuck/drf_orjson_renderer/actions/workflows/main.yml) `drf_orjson_renderer` is JSON renderer and parser for Django Rest Framework using the [orjson](https://github.com/ijl/orjson) library. Backed by [Rust](https://www.rust-lang.org/), orjson is safe, correct and _fast_. ⚡️ In addition, unlike some performance optimized DRF renderers, It also renders pretty printed JSON when requests are made via RestFramework's BrowsableAPI. You get: - The safety of Rust - The speed of orjson when requests are made with `Accept: appliation/json` HTTP header or when requests are made with an unspecified `Accept` header. - The convenience of formatted output when requested with `Accept: text/html`. - The ability to pass your own `default` function definition. ## Installation `pip install drf_orjson_renderer` You can then set the `ORJSONRenderer` class as your default renderer in your `settings.py` ```Python REST_FRAMEWORK = { "DEFAULT_RENDERER_CLASSES": ( "drf_orjson_renderer.renderers.ORJSONRenderer", "rest_framework.renderers.BrowsableAPIRenderer", ), } ``` To modify how data is serialized, specify options in your `settings.py` ```Python REST_FRAMEWORK = { "ORJSON_RENDERER_OPTIONS": ( orjson.OPT_NON_STR_KEYS, orjson.OPT_SERIALIZE_DATACLASS, orjson.OPT_SERIALIZE_NUMPY, ), } ``` Also you can set the `ORJSONParser` class as your default parser in your `settings.py` ```Python REST_FRAMEWORK = { "DEFAULT_PARSER_CLASSES": ( "drf_orjson_renderer.parsers.ORJSONParser", ), } ``` ## Passing Your Own `default` Function By default, the `ORJSONRenderer` will pass a `default` function as a helper for serializing objects that orjson doesn't recognize. That should cover the most common cases found in a Django web application. If you find you have an object it doesn't recognize you can pass your own default function by overriding the `get_renderer_context()` method of your view: ```Python from rest_framework.views import APIView from rest_framework.response import Response class MyView(APIView): def default(self, obj): if isinstance(obj, MyComplexData): return dict(obj) def get_renderer_context(self): renderer_context = super().get_renderer_context() renderer_context["default_function"] = self.default return renderer_context def get(self, request, *args, **kwargs): my_complex_data = MyComplexData() return Response(data=my_complex_data) ``` If you know your data is already in a format orjson natively [recognizes](https://github.com/ijl/orjson/#types) you can get a small performance boost by passing `None` to the `renderer_context`: ```Python def get_renderer_context(self): renderer_context = super().get_renderer_context() renderer_context["default_function"] = None return renderer_context ``` As of ORJSON version 3, 2-space indenting is supported in serialization. In order to take advantage of the RestFramework Browsable API, when the requested media type is not `application/json`, the ORJSON renderer will add `orjson.OPT_INDENT_2` to the options mask to pretty print your output. ## Numpy When this package was originally written ORJSON did not natively support serializing numpy types. This package provided an encoder class that overrides the DjangoJSONEncoder with support for numpy types. This encoder is no longer necessary but included for backwards compatibility. ```Python from drf_orjson_renderer.encoders import DjangoNumpyJSONEncoder from rest_framework.views import APIView class MyView(APIView): def get_renderer_context(self): renderer_context = super().get_renderer_context() renderer_context["django_encoder_class"] = DjangoNumpyJSONEncoder return renderer_context ``` ## Benchmarks See the [orjson Benchmarks](https://github.com/ijl/orjson#performance) for more information


نیازمندی

مقدار نام
>=3.2 django
- djangorestframework
>=3.3.0 orjson


زبان مورد نیاز

مقدار نام
>=3.6.0 Python


نحوه نصب


نصب پکیج whl drf-orjson-renderer-1.7.1:

    pip install drf-orjson-renderer-1.7.1.whl


نصب پکیج tar.gz drf-orjson-renderer-1.7.1:

    pip install drf-orjson-renderer-1.7.1.tar.gz