A reactive programming library for Python ported from Live Cells for Dart
Project description
Live Cells Python
This software is still in beta, and will likely experience rapid changes before the first official release.
Live Cells Python is a reactive programming library for Python, ported from Live Cells for Dart.
Installation
Run the following command to install Live Cells Python:
pip install live-cells-py
Examples
This section contains examples demonstrating the main features of the library. Head to the documentation, for more information on how to use this library.
The basic building block of Live Cells is the cell, which is an object with a value and a set of observers, which react to changes in the value.
Cells are defined as follows:
import live_cells as lc
a = lc.mutable(0)
a = lc.mutable(0)
And are observed as follows:
lc.watch(lambda: print(f'{a()}, {b()}'))
The watch function defined above prints the values of the cells a
and b
to standard output. It is called whenever the value of a
or
b
changes.
For example the following code, which sets the values of a
and b
:
a.value = 1
b.value = 2
a.value = 3
Results in the following being printed to standard output:
1, 0
1, 2
3, 2
Watch functions comprising multiple statements can be defined using
the decorator of watch
:
@lc.watch
def watcher():
print(f'A = {a()}')
print(f'B = {b()}')
Cells can also be defined as a function of the values of one or more
cells. For example the following cell is defined as the sum of cells
a
and b
:
c = lc.computed(lambda: a() + b())
The value of cell c
is recomputed automatically whenever the value
of either a
or b
changes.
This cell can also be defined more succinctly as an expression of cells:
c = a + b
That looks exactly like a normal variable definition.
This can be used to run a routine automatically whenever a certain condition is met. For example, let's print a message to standard output whenever the sum exceeds 100:
@lc.watch
def watch_sum():
if c() > 100:
print('Sum exceeds 100!!!')
When the following is executed:
a.value = 90
b.value = 30
The following message is printed to standard output automatically:
Sum exceeds 100!!!
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
File details
Details for the file live-cells-py-0.1.5.tar.gz
.
File metadata
- Download URL: live-cells-py-0.1.5.tar.gz
- Upload date:
- Size: 23.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 97f0d3bcebec4247fa250a8302f913d1e6ce31bd1ef33a6f32f6fad83a34e0e7 |
|
MD5 | 079e5c2b63be826a73579ac49055fe03 |
|
BLAKE2b-256 | 2146aa50d3503bb7a553cb2bb39bd612fb2804acc9b5c0d62921bd299f2cf00e |