A package providing streams and optional functionality similar to Java streams and optionals.
Project description
jstreams
jstreams is a Python library aiming to replicate the Java Streams and Optional functionality. The library is implemented with type safety in mind.
Installation
Use the package manager pip to install jstream.
pip install jstreams
Usage
Streams
from jstreams import Stream
# Applies a mapping function on each element then produces a new string
print(Stream(["Test", "Best", "Lest"]).map(str.upper).collect())
# will output ["TEST", "BEST", "LEST"]
# Filter the stream elements
print(Stream(["Test", "Best", "Lest"])
.filter(lambda s: s.startswith("T"))
.collect())
# Will output ['Test']
# isNotEmpty checks if the stream is empty
print(Stream(["Test", "Best", "Lest"])
.filter(lambda s: s.startswith("T"))
.isNotEmpty())
# Will output True
# Checks if all elements match a given condition
print(Stream(["Test", "Best", "Lest"]).allMatch(lambda s: s.endswith("est")))
# Will output True
print(Stream(["Test", "Best", "Lest"]).allMatch(lambda s: s.startswith("T")))
# Will output False
# Checks if any element matches a given condition
print(Stream(["Test", "Best", "Lest"]).anyMatch(lambda s: s.startswith("T")))
# Will output True
# Checks if no elements match the given condition
print(Stream(["Test", "Best", "Lest"]).noneMatch(lambda s: s.startswith("T")))
# Will output False
# Gets the first value of the stream as an Opt (optional object)
print(Stream(["Test", "Best", "Lest"])
.findFirst(lambda s: s.startswith("L"))
.getActual())
# Will output "Lest"
# Returns the first element in the stream
print(Stream(["Test", "Best", "Lest"]).first())
# Will output "Test"
# cast casts the elements to a different type. Useful if you have a stream
# of base objects and want to get only those of a super class
print(Stream(["Test1", "Test2", 1, 2])
.filter(lambda el: el == "Test1")
# Casts the filtered elements to the given type
.cast(str)
.first())
# Will output "Test1"
# If the stream elements are Iterables, flatMap will produce a list of all contained items
print(Stream([["a", "b"], ["c", "d"]]).flatMap(list).toList())
# Will output ["a", "b", "c", "d"]
# reduce will produce a single value, my applying the comparator function given as parameter
# in order to decide which value is higher. The comparator function is applied on subsequent elements
# and only the 'highest' one will be kept
print(Stream([1, 2, 3, 4, 20, 5, 6]).reduce(max).getActual())
# Will output 20
# notNull returns a new stream containing only non null elements
print(Stream(["A", None, "B", None, None, "C", None, None]).nonNull().toList())
# Will output ["A", "B", "C"]
Opt
from jstreams import Opt
# Checks if the value given is present
Opt(None).isPresent() # Will return False
Opt("test").isPresent() # Will return True
# There are two ways of getting the value from the Opt object. The get returns a non optional
# value and will raise a value error if the object is None. On the other hand, getActual returns
# an optional object and does not raise a value error
Opt("test").get() # Does not fail, and returns the string "test"
Opt(None).get() # Raises ValueError since None cannot be casted to any type
Opt(None).getActual() # Returns None, does not raise value error
# The ifPresent method will execute a lambda function if the object is present
Opt("test").ifPresent(lambda s: print(s)) # Will print "test"
Opt(None).ifPresent(lambda s: print(s)) # Does nothing, since the object is None
# The getOrElse method will return the value of the Opt if not None, otherwise the given parameter
Opt("test").getOrElse("test1") # Will return "test", since the value is not None
Opt(None).getOrElse("test1") # Will return "test1", since the value is None
# The getOrElseGet method will return the value of the Opt if not None, otherwise it will execute
# the given function and return its value
Opt("test").getOrElseGet(lambda: "test1") # Will return "test", since the value is not None
Opt(None).getOrElseGet(lambda: "test1") # Will return "test1", since the value is None
# stream will convert the object into a stream.
Opt("test").stream() # Is equivalent with Stream(["test"])
Opt(["test"]).stream() # Is equivalent with Stream([["test"]]). Notice the list stacking
# flatStream will convert the object into a stream, with the advantage that it can
# detect whether the object is a list and avoids stacking lists of lists.
Opt("test").flatStream() # Is equivalent with Stream(["test"])
Opt(["test", "test1", "test2"]).flatStream() # Is equivalent with Stream(["test", "test1", "test2"])
Try
# The Try class handles a chain of function calls with error handling
def throwErr() -> None:
raise ValueError("Test")
def returnStr() -> str:
return "test"
# It is important to call the get method, as this method actually triggers the entire chain
Try(throwErr).onFailure(lambda e: print(e)).get() # The onFailure is called
Try(returnStr).andThen(lambda s: print(s)).get() # Will print out "test"
# The of method can actually be used as a method to inject a value into a Try without
# actually calling a method or lambda
Try.of("test").andThen(lambda s: print(s)).get() # Will print out "test"
License
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
jstreams-1.0.11.tar.gz
(10.9 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file jstreams-1.0.11.tar.gz.
File metadata
- Download URL: jstreams-1.0.11.tar.gz
- Upload date:
- Size: 10.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cc3ef148691b93db760d76a5f65fe89cd3cbfebdd772fed66c1b59657d52b895
|
|
| MD5 |
1d53d36de860508bf0040bb969f73639
|
|
| BLAKE2b-256 |
3feec7ed74cf32860f48af543fd5748b82797b20a0314be49d6d630e82ff2bc1
|
File details
Details for the file jstreams-1.0.11-py3-none-any.whl.
File metadata
- Download URL: jstreams-1.0.11-py3-none-any.whl
- Upload date:
- Size: 9.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
caae7995f7449e4f5059be91670a1b8212b95c5689376a4425400c54bf83ba29
|
|
| MD5 |
bf5dd6dcb680a91001311370d95ef04d
|
|
| BLAKE2b-256 |
df10fb53e7397567df4ae20de402819a790a4cce2d741090d8331c039bbf42dd
|