Tkapi
Python bindings for the Tweede Kamer OData API
Install / Use
/learn @openkamer/TkapiREADME
tkapi
Python ORM and bindings for the Tweede Kamer Open Data Portaal OData API.
A pure Python interface for the Tweede Kamer API with type annotations for easy data model discovery.
Requires Python 3.5+.
Please create an issue if you have any problems, questions or suggestions.
Installation
pip install tkapi
Data model
See Open Kamer Data Model documentation for the data model that is mapped to Python classes.
Usage
A simple first example,
import tkapi
api = tkapi.TKApi()
personen = api.get_personen(max_items=100)
for persoon in personen:
print(persoon.achternaam)
For more examples see the examples and tests.
Entities
See Tweede Kamer documentation for details.
| Algemeen | Persoon | Fractie | Commissie | |-----------------------------|-------------------------------|--------------------------|---------------------------------| | Activiteit | Persoon | Fractie | Commissie | | ActiviteitActor | PersoonContactinformatie | FractieZetel | CommissieContactinformatie | | Agendapunt | PersoonFunctie | FractieZetelPersoon | CommissieZetel | | Besluit | PersoonGeschenk | FractieZetelVacature | CommissieZetelVastPersoon | | Document | PersoonLoopbaan | FractieZetelVacature | CommissieZetelVastVacature | | DocumentActor | PersoonNevenfunctie | | CommissieZetelVervangerPersoon | | DocumentVersie | PersoonNevenfunctieInkomsten | | CommissieZetelVervangerVacature | | Kamerstukdossier | PersoonOnderwijs | | | | Reservering | PersoonReis | | | | Stemming | | | | | Vergadering | | | | | Verslag | | | | | Zaak | | | | | ZaakActor | | | | | Zaal | | | |
Development
Tests
Run all tests,
pytest
Coverage report
Run all tests,
coverage run -m unittest discover
Create coverage report,
coverage html
Then visit htmlcov/index.html in your browser.
Publishing
This project uses Python packaging with pyproject.toml. To publish a new version to PyPI:
-
Install build tools (if not already installed):
pip install build twine -
Update the version in
pyproject.toml:version = "X.Y.Z" -
Build the package:
python -m buildThis will create distribution files in the
dist/directory. -
Test the build locally (optional but recommended):
pip install dist/tkapi-X.Y.Z-py3-none-any.whl -
Upload to Test PyPI (optional, for testing):
twine upload --repository-url https://test.pypi.org/legacy/ dist/* -
Upload to PyPI:
twine upload dist/*You'll need PyPI credentials (username and password/token). You can create an API token at https://pypi.org/manage/account/token/
Related Skills
node-connect
354.3kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
112.3kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
354.3kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
qqbot-media
354.3kQQBot 富媒体收发能力。使用 <qqmedia> 标签,系统根据文件扩展名自动识别类型(图片/语音/视频/文件)。
