NiceCRUD is a CRUD (Create, Read, Update, Delete) interface built with python. The library integrates with pydantic models and NiceGUI to handle data manipulation with a browser interface.
- Automatically generate CRUD interfaces from pydantic models.
- Field options, ranges, constraints, descriptions etc. are directly taken from your pydantic model
- Integrated validation and error handling with pydantic.
- Support for nested models and selection options.
- Inject your own (database?) update methods
- Minimal configuration required with sensible defaults.
Taken from the input_choices example:
To install NiceCRUD, use pip:
pip install niceguicrudHere is a very basic example:
from nicegui import ui
from pydantic import BaseModel, Field
from niceguicrud import NiceCRUD
class MyModel(BaseModel, title="User"):
    id: int
    name: str = Field(title="Name")
    age: int = Field(gt=0, title="Age")
instance1 = MyModel(id=1, name="Alice", age=30)
instance2 = MyModel(id=2, name="Bob", age=25)
crud_app = NiceCRUD(basemodels=[instance1, instance2], id_field="id", heading="User Management")
ui.run()Find more in the examples folder.
| Example Name | Description | 
|---|---|
| minimal | The above minimal example | 
| validation | Example showcasing how pydantic validation features are used in the GUI | 
| submodel | Demonstrates usage of a pydantic submodel that can also be used in the GUI. | 
| input_choices | Shows the different input choices. | 
| database | Shows how to customize the update, create and delete operations | 
Contributions are welcome!
Make sure that the environment variable UV_PUBLISH_TOKEN is set to a pypi secret token.
uv build
uv publishThis project is licensed under the MIT License. See the LICENSE.