Skip to main content

The Python interface to themeontology.org.

Project description

PyPI version codecov Life cycle downloads License: MIT

totolo

A Python package for working with data from the Theme Ontology theming repository.

pip install totolo

Or clone this repository and copy the totolo directory wherever you need it. No package dependencies are required.

erDiagram
    "<A href='https://github.com/theme-ontology/python-totolo/blob/main/totolo/ontology.py'>ontology</A>" ||--o{ "<A href='https://github.com/theme-ontology/python-totolo/blob/main/totolo/story.py'>story</A>" : "ontology[<i>story.name</i>]"
    "<A href='https://github.com/theme-ontology/python-totolo/blob/main/totolo/ontology.py'>ontology</A>" ||--o{ "<A href='https://github.com/theme-ontology/python-totolo/blob/main/totolo/theme.py'>theme</A>" : "ontology[<i>theme.name</i>]"
    "<A href='https://github.com/theme-ontology/python-totolo/blob/main/totolo/theme.py'>theme</A>" ||--|{ "<A href='https://github.com/theme-ontology/python-totolo/blob/main/totolo/field.py'>field</A>" : "theme.get(<i>field_name</i>)"
    "<A href='https://github.com/theme-ontology/python-totolo/blob/main/totolo/story.py'>story</A>" ||--|{ "<A href='https://github.com/theme-ontology/python-totolo/blob/main/totolo/field.py'>field</A>" : "story.get(<i>field_name</i>)"
    "<A href='https://github.com/theme-ontology/python-totolo/blob/main/totolo/story.py'>story</A>" ||--o{ "(<i>weight</i>, <A href='https://github.com/theme-ontology/python-totolo/blob/main/totolo/keyword.py'>kw</A>)" : "story.iter_theme_entries()"
    "(<i>weight</i>, <A href='https://github.com/theme-ontology/python-totolo/blob/main/totolo/keyword.py'>kw</A>)" 1--1 "<i>theme.name</i>" : "kw.keyword"
    "<A href='https://github.com/theme-ontology/python-totolo/blob/main/totolo/field.py'>field</A>" 1--1 "<i>metadata like 'Title', 'Description', 'References', etc.</i>": "field.str()"

totolo - Overview

Inline documentation: ontology, story, theme, field, keyword.

Create an ontology object by, for example, fetching a named version remotely. On the ontology object access stories or themes using their unique name and bracket notation. Access basic information on the theme or story by accessing named fields using the get-method. Named fields are defined with the "sa" annotation in the story and theme source code linked above at the top of the respective class. Access minor/major/choice theme entries on a story by iterating over them.

ontology = totolo.remote('v2025.04')
theme = ontology['theme_name']
story = ontology['story_name']
theme_description = theme.get("Description").str()
story_references = story.get("References").str()
for weight, keyword in story.iter_theme_entries():
    ...

Python's builtin methods help() and dir() yield useful information on any of these objects. The above linked source code for them is intended to be readable. For any story, theme, field or keyword objects you can obtain a text representation that is the same as it would be if the ontology was written to file.

_ = story.text(); story.print()
_ = theme.text(); theme.print()
_ = field.str(); print(field)
_ = keyword.str(); print(keyword)

Although totolo can be used to programmatically edit the structure of the ontology, the documentation is foremost intended for those who read the ontology to analyse it in python or feed it forwards.

totolo - Basic Usage

    #: import package
    >>> import totolo

    #: get the latest main branch version of the ontology
    >>> ontology = totolo.remote()
    >>> print(ontology)
<2945 themes, 4475 stories>

    #: write it or read it locally
    >>> ontology.write("/home/mo/themes")
    >>> ontology = totolo.files("/home/mo/themes")
    >>> print(ontology)
<2945 themes, 4475 stories>
Explore the stories
    >>> story = ontology["movie: Ran (1985)"]
    >>> for weight, theme in story.iter_themes():
    ...     print(f"{weight:<15} {theme.name}")
Choice Themes   betrayal
Choice Themes   the lust for power
(...)
Explore the themes
    #: go over all the themes and find the ones you want
    >>> for theme in ontology.themes():
    ...     if "romantic love" in theme.name:
    ...         print(theme)
b'personal freedom vs. romantic love'[3]
b'romantic love'[3]

    #: check the definition of a theme
    >>> love = ontology["love"]
    >>> love.print()
    (...)
Convert it to a pandas dataframe
    >>> df = ontology.dataframe()
    >>> df
                                 story_id             title        date                      theme        weight
0                 theamericanshortstory01  The Music School        1974      human self-reflection  Major Themes
1                 theamericanshortstory01  The Music School        1974                     murder  Major Themes
...                                   ...               ...         ...                        ...           ...
52453  videogame: Final Fantasy VI (1994)  Final Fantasy VI  1994-04-02  feral children in society  Minor Themes
52454  videogame: Final Fantasy VI (1994)  Final Fantasy VI  1994-04-02             father and son  Minor Themes

[52455 rows x 5 columns]

totolo - Snippets

List official versioned releases of the ontology, then load one
    print(list(totolo.remote.versions()))
    ontology = totolo.remote.version('v2023.06')
Create an excel sheet with all the usages of the theme "loyalty" as well as any child theme of the same
    df = ontology['loyalty'].descendants().dataframe(motivation=True, descriptions=True)
    df.to_excel("/mnt/d/repos/themelist-loyalty.xlsx", "loyalty")
Find theme entries in stories according to some criteria, for example, find empty motivations
    empty_motivations = [
        (story, weight, part)
        for story in ontology.stories()
        for weight, part in story.iter_theme_entries()
        if part.motivation.strip() == ""
    ]

totolo - Getting Help

If you encounter a bug, please file a minimal reproducible example on GitHub issues. For feature requests and other matters, please post on the GitHub discussions board.

Files and Code Test Coverage

codecov

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

totolo-2.1.2.tar.gz (1.4 MB view details)

Uploaded Source

Built Distribution

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

totolo-2.1.2-py2.py3-none-any.whl (34.1 kB view details)

Uploaded Python 2Python 3

File details

Details for the file totolo-2.1.2.tar.gz.

File metadata

  • Download URL: totolo-2.1.2.tar.gz
  • Upload date:
  • Size: 1.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for totolo-2.1.2.tar.gz
Algorithm Hash digest
SHA256 8fccb7818fb36db0c8625495d3d9e31496aaead0304a42cde9c8566effbe8494
MD5 6b97d0ad8df310a89071c8750bcab86b
BLAKE2b-256 3ba2a3a8d66a71b84274e99121689fdb47eb1abe55811196d247de112c1ec11a

See more details on using hashes here.

Provenance

The following attestation bundles were made for totolo-2.1.2.tar.gz:

Publisher: publish.yaml on theme-ontology/python-totolo

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

File details

Details for the file totolo-2.1.2-py2.py3-none-any.whl.

File metadata

  • Download URL: totolo-2.1.2-py2.py3-none-any.whl
  • Upload date:
  • Size: 34.1 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for totolo-2.1.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 241f3c47f687c29888e75f7818d6e5b02bcabde0bf86f5b534a718d4545c70b9
MD5 0c75f60d851c4881fbaabca79b533ce6
BLAKE2b-256 ff35340bba1ecd74c9d5c5ab4f699813f580f73cfc39fbd681bec1ed59d4a398

See more details on using hashes here.

Provenance

The following attestation bundles were made for totolo-2.1.2-py2.py3-none-any.whl:

Publisher: publish.yaml on theme-ontology/python-totolo

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