Skip to main content

ReactiveX (Rx) for Python

Project description

Build Status Coverage Status PyPY Package Version Documentation Status

A library for composing asynchronous and event-based programs using observable collections and query operator functions in Python

ReactiveX for Python v5

For v3.X please go to the v3 branch.

ReactiveX for Python v4.x runs on Python 3.9 or above. To install:

pip3 install reactivex

About ReactiveX

ReactiveX for Python (RxPY) is a library for composing asynchronous and event-based programs using observable sequences and pipable query operators in Python. Using Rx, developers represent asynchronous data streams with Observables, query asynchronous data streams using operators, and parameterize concurrency in data/event streams using Schedulers.

import reactivex as rx
from reactivex import operators as ops

source = rx.of("Alpha", "Beta", "Gamma", "Delta", "Epsilon")

composed = source.pipe(
    ops.map(lambda s: len(s)),
    ops.filter(lambda i: i >= 5)
)
composed.subscribe(lambda value: print("Received {0}".format(value)))

Fluent and Functional Syntax

RxPY supports both fluent (method chaining) and functional (pipe-based) syntax, giving you the flexibility to choose the style that works best for your codebase:

Fluent style - Method chaining for a more Pythonic feel:

import reactivex as rx

result = (rx.of(1, 2, 3, 4, 5)
    .map(lambda x: x * 2)
    .filter(lambda x: x > 5)
    .reduce(lambda acc, x: acc + x, 0)
)
result.subscribe(print)  # Output: 24

Functional style - Pipe-based for functional composition:

import reactivex as rx
from reactivex import operators as ops

result = rx.of(1, 2, 3, 4, 5).pipe(
    ops.map(lambda x: x * 2),
    ops.filter(lambda x: x > 5),
    ops.reduce(lambda acc, x: acc + x, 0)
)
result.subscribe(print)  # Output: 24

Both styles are fully supported and can even be mixed in the same pipeline. Choose the style that best fits your team’s preferences and coding standards.

Learning ReactiveX

Read the documentation to learn the principles of ReactiveX and get the complete reference of the available operators.

If you need to migrate code from RxPY v1.x or v3.x, read the migration section.

There is also a list of third party documentation available here.

Community

Join the conversation on GitHub Discussions! if you have any questions or suggestions.

Differences from .NET and RxJS

ReactiveX for Python is a fairly complete implementation of Rx with more than 120 operators, and over 1300 passing unit-tests. RxPY is mostly a direct port of RxJS, but also borrows a bit from Rx.NET and RxJava in terms of threading and blocking operators.

ReactiveX for Python follows PEP 8, so all function and method names are snake_cased i.e lowercase with words separated by underscores as necessary to improve readability.

Thus .NET code such as:

var group = source.GroupBy(i => i % 3);

need to be written with an _ in Python:

# Functional style
group = source.pipe(ops.group_by(lambda i: i % 3))

# Or fluent style
group = source.group_by(lambda i: i % 3)

With ReactiveX for Python you should use named keyword arguments instead of positional arguments when an operator has multiple optional arguments. RxPY will not try to detect which arguments you are giving to the operator (or not).

Development

This project is managed using uv. Code is formatted using Ruff. Code is statically type checked using pyright.

After cloning the repository, install dependencies:

uv sync

Run unit tests:

uv run pytest

Run type checking:

uv run pyright

Run code checks (manually):

uv run pre-commit run --all-files

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

reactivex-5.0.0rc1.tar.gz (136.2 kB view details)

Uploaded Source

Built Distribution

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

reactivex-5.0.0rc1-py3-none-any.whl (255.9 kB view details)

Uploaded Python 3

File details

Details for the file reactivex-5.0.0rc1.tar.gz.

File metadata

  • Download URL: reactivex-5.0.0rc1.tar.gz
  • Upload date:
  • Size: 136.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for reactivex-5.0.0rc1.tar.gz
Algorithm Hash digest
SHA256 63783948131ffb6f47aa672b5f078bb8be8310311f969657791dfd06ddac1cce
MD5 ba25b19e97e1ea5e96840d73fd2454a1
BLAKE2b-256 3c1a8d6ce00544ddc99d46841a714d086be1df572890569bbb305cef58ae2366

See more details on using hashes here.

File details

Details for the file reactivex-5.0.0rc1-py3-none-any.whl.

File metadata

  • Download URL: reactivex-5.0.0rc1-py3-none-any.whl
  • Upload date:
  • Size: 255.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for reactivex-5.0.0rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 445fcf7590db8d1d73dcc16c8c8bec93b83817f1a0bf629c2b735c6e06e7a44e
MD5 5d74403590467d0ca002071d45e74054
BLAKE2b-256 cf9f21d6b1e081f136e10cd0d0886c4a1e3f1b5425dae629393522a70cdad8a6

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