Python library for FOLIO, the Federated Open Legal Information Ontology
Project description
FOLIO Python Library
The FOLIO Python Library provides a simple and efficient way to interact with the Federated Open Legal Information Ontology (FOLIO).
FOLIO is an open, CC-BY licensed standard designed to represent universal elements of legal data, improving communication and data interoperability across the legal industry.
Features
- Load the FOLIO ontology from GitHub or a custom HTTP URL
- Search for classes by label or definition
- Get subclasses and parent classes
- Access detailed information about each class, including labels, definitions, and examples
- Explore semantic relationships through object properties
- Find connections between entities using labeled relationships
- Analyze property usage, domains, and ranges
- Convert classes to OWL XML, JSON-LD, or Markdown format
Changelog
The changelog can be found at CHANGES.md.
Installation
You can install the FOLIO Python library using pip:
pip install folio-python
For the latest development version, you can install directly from GitHub:
pip install --upgrade https://github.com/alea-institute/folio-python/archive/refs/heads/main.zip
Quick Start
Here's a simple example to get you started with the FOLIO Python library:
from folio import FOLIO
# Initialize the FOLIO client
folio = FOLIO()
# Search by prefix
results = folio.search_by_prefix("Mich")
for owl_class in results:
print(f"Class: {owl_class.label}")
# Search for a class by label
results = folio.search_by_label("Mich")
for owl_class, score in results:
print(f"Class: {owl_class.label}, Score: {score}")
# Get all areas of law
areas_of_law = folio.get_areas_of_law()
for area in areas_of_law:
print(area.label)
# Working with object properties
properties = folio.get_all_properties()
print(f"Number of object properties: {len(properties)}")
# Get properties by label
drafted_properties = folio.get_properties_by_label("folio:drafted")
for prop in drafted_properties:
print(f"Property: {prop.label}")
print(f"Domain: {[folio[d].label for d in prop.domain if folio[d]]}")
print(f"Range: {[folio[r].label for r in prop.range if folio[r]]}")
# Find connections between entities
connections = folio.find_connections(
subject_class="https://folio.openlegalstandard.org/R8CdMpOM0RmyrgCCvbpiLS0", # Actor/Player
property_name="folio:drafted"
)
for subject, property_obj, object_class in connections:
print(f"{subject.label} {property_obj.label} {object_class.label}")
Searching with an LLM
# Search with an LLM
async def search_example():
for result in await folio.parallel_search_by_llm(
"redline lease agreement",
search_sets=[
folio.get_areas_of_law(max_depth=1),
folio.get_player_actors(max_depth=2),
],
):
print(result)
import asyncio
asyncio.run(search_example())
LLM search uses the alea_llm_client to provide abstraction across multiple APIs and providers.
Documentation
For more detailed information about using the FOLIO Python library, please refer to our full documentation.
Contributing
We welcome contributions to the FOLIO Python library! If you'd like to contribute, please follow these steps:
- Fork the repository
- Create a new branch for your feature or bug fix
- Make your changes and write tests if applicable
- Run the test suite to ensure everything is working
- Submit a pull request with a clear description of your changes
For more information, see our contribution guidelines.
FOLIO API
A public, freely-accessible API is available for the FOLIO ontology.
The API is hosted at https://folio.openlegalstandard.org/.
The source code for the API is available on GitHub at https://github.com/alea-institute/folio-api.
License
The FOLIO Python library is released under the MIT License. See the LICENSE file for details.
Support
If you encounter any issues or have questions about using the FOLIO Python library, please open an issue on GitHub.
Learn More
To learn more about FOLIO, its development, and how you can get involved, visit the FOLIO website or join the FOLIO community forum.
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
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 folio_python-0.2.0.tar.gz.
File metadata
- Download URL: folio_python-0.2.0.tar.gz
- Upload date:
- Size: 24.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.23
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d7e7adf9462288c020a7e005824c632571fa2914dbdc40bdd85f10061d080a43
|
|
| MD5 |
b1a6f9c1e314c8685a1726a0ae86fd23
|
|
| BLAKE2b-256 |
b7f5df40415506edd79bd09676dc1dd9f30e4d55403b1f02b7ba4cdb6c5baeb6
|
File details
Details for the file folio_python-0.2.0-py3-none-any.whl.
File metadata
- Download URL: folio_python-0.2.0-py3-none-any.whl
- Upload date:
- Size: 24.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.23
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9b1c135cb72e10a55d07c2f2b09facc3fe8e6d4aaee4c930f2b227d8daff5dec
|
|
| MD5 |
f9513ac0d2acd5341caee02a1d7a291d
|
|
| BLAKE2b-256 |
244449899ccd441564b382275ffd57fc024c22d9edecd1ce4c4143765103ccc7
|