Skip to main content

Library for conversions to/from the Commonmeta scholarly metadata format

Project description

DOI Build PyPI version Coverage Maintainability Rating docs GitHub

commonmeta-py

commonmeta-py is a Python library to implement Commonmeta, the common Metadata Model for Scholarly Metadata. Use commonmeta-py to convert scholarly metadata, in a variety of formats, listed below. Commonmeta-py is work in progress, the first release on PyPi (version 0.5.0) was on February 16, 2023. Up until version 0.5.1, the library was called talbot. Commonmeta-py is modelled after the commonmeta-ruby ruby gem.

commonmeta-py uses semantic versioning. Currently, its major version number is still at 0, meaning the API is not yet stable, and breaking changes are expected in the internal API and commonmeta JSON format.

Installation

Stable version

uv add commonmeta-py

Supported Metadata Formats

Commometa-py reads and/or writes these metadata formats:

Format Name Content Type Read Write
Commonmeta commonmeta application/vnd.commonmeta+json yes yes
CrossRef XML crossref_xml application/vnd.crossref.unixref+xml yes yes
Crossref crossref application/vnd.crossref+json yes n/a
DataCite datacite application/vnd.datacite.datacite+json yes yes
Schema.org (in JSON-LD) schema_org application/vnd.schemaorg.ld+json yes yes
RDF XML rdf_xml application/rdf+xml no later
RDF Turtle turtle text/turtle no later
CSL-JSON csl application/vnd.citationstyles.csl+json yes yes
Formatted text citation citation text/x-bibliography n/a yes
Codemeta codemeta application/vnd.codemeta.ld+json yes later
Citation File Format (CFF) cff application/vnd.cff+yaml yes later
JATS jats application/vnd.jats+xml later later
CSV csv text/csv no later
BibTex bibtex application/x-bibtex later yes
RIS ris application/x-research-info-systems yes yes
InvenioRDM inveniordm application/vnd.inveniordm.v1+json yes yes
JSON Feed jsonfeed application/feed+json yes later
OpenAlex openalex yes no

commonmeta: the Commonmeta format is the native format for the library and used internally. Planned: we plan to implement this format for the v1.0 public release. Later: we plan to implement this format in a later release.

Documentation

Documentation (work in progress) for using the library is available at the commonmeta-py Documentation website and includes several interactive Jupyter Notebooks .

This repository includes a Nixpacks configuration to build and serve the Quarto documentation site in the docs/ folder.

Coolify setup

  • App type: Nixpacks
  • Repository/branch: this repo, main
  • Build: auto-detected via Nixpacks
  • Port: Coolify provides PORT. The start command respects ${PORT} and falls back to 3000 for local runs.
  • Healthcheck: HTTP path /, interval 10s, timeout 5s, retries 3

Meta

Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.

License: MIT

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

commonmeta_py-0.227.tar.gz (1.8 MB view details)

Uploaded Source

Built Distribution

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

commonmeta_py-0.227-py3-none-any.whl (1.9 MB view details)

Uploaded Python 3

File details

Details for the file commonmeta_py-0.227.tar.gz.

File metadata

  • Download URL: commonmeta_py-0.227.tar.gz
  • Upload date:
  • Size: 1.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.5

File hashes

Hashes for commonmeta_py-0.227.tar.gz
Algorithm Hash digest
SHA256 60d94c0e26b622506e1a562f86b71f9ca19b48cd3a82f51245abec97d302c355
MD5 6c49d9fe30cafbd74115f9995bb1e4d2
BLAKE2b-256 e2e41ca3ec6ec58479c3d02ffa906f852b140a7b3383d99fb18d5a2e5c7ae8ed

See more details on using hashes here.

File details

Details for the file commonmeta_py-0.227-py3-none-any.whl.

File metadata

File hashes

Hashes for commonmeta_py-0.227-py3-none-any.whl
Algorithm Hash digest
SHA256 0825ef2f85bcc7369c08a9981c33578cc9c13c99af8f2d7315294125486e5ff4
MD5 7387f5e8b346d570dc7f0077c53c74ae
BLAKE2b-256 b453e4d672b88538526f6d976622151a014eed21872e0aa7184e5599f3ef3f19

See more details on using hashes here.

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