Skip to main content

SQLite API for plexos XMLs

Project description

plexosdb

SQLite-backed Python API for reading, building, and writing PLEXOS XML models

image image image CI codecov Ruff Documentation

plexosdb converts PLEXOS XML input files into an in-memory SQLite database, giving you a fast, typed Python API to query, create, and modify power system models programmatically, then write them back to XML.

Installation

pip install plexosdb

Or with uv:

uv add plexosdb

Python version support: 3.11, 3.12, 3.13, 3.14

Quick Start

from plexosdb import PlexosDB, ClassEnum, CollectionEnum

# Load a PLEXOS XML file into an in-memory SQLite database
db = PlexosDB.from_xml("model.xml")

# Query existing objects
generators = db.get_object_names(ClassEnum.Generator)

# Add new objects
db.add_object(ClassEnum.Generator, name="SolarPV_01", category="Renewables")
db.add_object(ClassEnum.Node, name="Bus_1")

# Create memberships between objects
db.add_membership(
    CollectionEnum.GeneratorNodes,
    parent_class=ClassEnum.Generator,
    parent_name="SolarPV_01",
    child_class=ClassEnum.Node,
    child_name="Bus_1",
)

# Export the modified model back to XML
db.to_xml("modified_model.xml")

Documentation

Full documentation is available at natlabrockies.github.io/plexosdb.

Developer Setup

plexosdb uses uv for dependency management.

git clone https://github.com/NatLabRockies/plexosdb.git
cd plexosdb
uv sync --all-groups

Install the git hooks so your code is checked before making commits:

uv run prek install

Run the test suite:

uv run pytest

License

This software is released under a BSD-3-Clause License.

This software was developed under software record SWR-24-90 at the National Renewable Energy Laboratory (NREL).

Disclaimer

PLEXOS is a registered trademark of Energy Exemplar Pty Ltd. Energy Exemplar Pty Ltd. has no affiliation to or participation in this software. Reference herein to any specific commercial products, process, or service by trade name, trademark, manufacturer, or otherwise, does not necessarily constitute or imply its endorsement, recommendation, or favoring by the United States Government or Alliance for Sustainable Energy, LLC ("Alliance"). The views and opinions of authors expressed in the available or referenced documents do not necessarily state or reflect those of the United States Government or Alliance.

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

plexosdb-1.4.1.tar.gz (53.4 kB view details)

Uploaded Source

Built Distribution

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

plexosdb-1.4.1-py3-none-any.whl (57.8 kB view details)

Uploaded Python 3

File details

Details for the file plexosdb-1.4.1.tar.gz.

File metadata

  • Download URL: plexosdb-1.4.1.tar.gz
  • Upload date:
  • Size: 53.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for plexosdb-1.4.1.tar.gz
Algorithm Hash digest
SHA256 53612d17e37172a95f5b518a3c65d9032351d3351d2e33ea4382adebb1d38aea
MD5 5ddf7b5a88f69a775acc2bbbb58e8219
BLAKE2b-256 b5de6868f6d95557b913dc0debfb5df3f6156c70b7010f8b924a75159cd41b0b

See more details on using hashes here.

Provenance

The following attestation bundles were made for plexosdb-1.4.1.tar.gz:

Publisher: release.yaml on NatLabRockies/plexosdb

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file plexosdb-1.4.1-py3-none-any.whl.

File metadata

  • Download URL: plexosdb-1.4.1-py3-none-any.whl
  • Upload date:
  • Size: 57.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for plexosdb-1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4231854af242b0abd9c2406c41a42707c3510042f6167a11a9b0299edf22cbc8
MD5 7dff0390ff86fa1e8831b1ae869cf2c0
BLAKE2b-256 cdc428589c6b04c50b07626ac1a924ba445ac3412adae1a95d5667a2edfa3b9b

See more details on using hashes here.

Provenance

The following attestation bundles were made for plexosdb-1.4.1-py3-none-any.whl:

Publisher: release.yaml on NatLabRockies/plexosdb

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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