Skip to main content

MeSH subject terms without qualifiers

Project description

invenio-subjects-mesh-lite

MeSH topical subject terms without qualifiers for InvenioRDM

Install this extension to get Medical Subject Headings topics without qualifiers into your instance.

If you are looking for a larger MeSH vocabulary with qualifiers, use invenio-subjects-mesh instead.

[!NOTE] Both extensions map the MeSH subject id, so you can only install one of them. However, they use the same pattern for subject ids, so you can switch from one to the other easily if your needs change in the future.

Installation

From your instance directory:

pipenv install invenio-subjects-mesh-lite

This will add it to your Pipfile.

Versions

From 2025.1.15.2 onwards

This package follows the following format for versions: YYYY.mm.dd.patch where

  • YYYY.mm.dd is the date of retrieval of the MeSH terms with mm and dd NOT being 0-prefixed.
  • patch is the patch number (0-indexed) so that multiple releases can be done on the same day (bug/security fixes) and non-subject related releases can be done as well.

This follows calendar versioning (for year, month, and day) and adds a patch number at the end. The package is typically updated on a quarterly basis. The following are illustrative (fictitious) examples of how to understand the versioning of this distribution package:

Last MeSH update included patch number version of this project
2025-06-31 2 2025.6.31.2
2025-12-01 0 2025.12.1.0

Prior to 2025.1.15.2

This repository follows calendar versioning for year and month. It does a "best effort" attempt at tracking the MeSH updates in an up-to-and-including version date manner. The following are illustrative cases of how to understand the versioning of this distribution package:

Last MeSH update included version of this project date of release of this project
2024-01-31 2024.1.X any time after 2024-01-31
2023-12-31 2023.12.X any time after 2023-12-31

2021.06.18 is both a valid semantic version and an indicator of the year-month corresponding to the loaded terms. 18 here is a patch number (not a day).

Usage

There are 2 types of users for this package. Instance operators and package maintainers.

Instance operators

For instance operators, after you have installed the extension as per the steps above, you will want to reload your instance's fixtures: pipenv run invenio rdm-records fixtures. This will install the new terms in your instance.

Alternatively, or if you want to update your already loaded subjects to a new listing (e.g. from one year's list to another), you can update your instance's MeSH subjects as per below. Updating subjects this way takes care of everything for you: the subjects themselves and the records/drafts using those subjects. WARNING This operation can remove subjects.

# In your instance's project
# Download up-to-date listings
pipenv run invenio galter_subjects mesh download -d /path/to/downloads/storage/ -y YEAR
# Generate file containg deltas to transition your instance to the downloaded listing
pipenv run invenio galter_subjects mesh deltas -d /path/to/downloads/storage/ -y YEAR -f topic -o deltas_mesh.csv
# Update your instance - *this operation will modify your instance*
pipenv run invenio galter_subjects update deltas_mesh.csv

Look at the help text for these commands to see additional options that can be passed. In particular, options for galter_subjects update allow you to store renamed, replaced or removed subjects on records according to a template of your choice.

Maintainers

When a new list of MeSH term comes out, this package should be updated. Here we show how.

Pre-requisite/Context

Install the distribution package for development before you do anything.

Commands

Once you have it installed, you can run the following commands in the isolated virtualenv:

# In this project
# Download up-to-date listings
(venv) invenio galter_subjects mesh download -d /path/to/downloads/storage/ -y YEAR
# Generate file containing initial listing
(venv) invenio galter_subjects mesh file -d /path/to/downloads/storage/ -y YEAR -f topic -o invenio_subjects_mesh_lite/vocabularies/subjects_mesh.csv

Sorting the resulting csv is a nice touch for humans to better parse the changes between versions.

When you are happy with the list, bump the version in pyproject.toml and release it.

Development

Install the project in editable mode with dev dependencies in an isolated virtualenv ((venv) denotes that going forward):

(venv) pip install -e .[dev]
# or if using pipenv
pipenv run pip install -e .[dev]

Run tests:

(venv) invoke test
# or shorter
(venv) inv test
# or if using pipenv
pipenv run inv test

Test compatibility with the pre-release version of InvenioRDM (invenio-app-rdm):

# Step 1 - install the pre-release dependencies
(venv) pip install --pre -e .[dev_pre]
# Step 2 - Run the pre-release tests
(venv) inv test
# if using uv run:
uv run --extra dev_pre --prerelease=allow inv test

Check manifest:

(venv) inv check-manifest
# or if using pipenv
pipenv run inv check-manifest

Clean out artefacts:

(venv) inv clean
# or if using pipenv
pipenv run inv clean

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

invenio_subjects_mesh_lite-2026.1.27.0.tar.gz (352.6 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file invenio_subjects_mesh_lite-2026.1.27.0.tar.gz.

File metadata

File hashes

Hashes for invenio_subjects_mesh_lite-2026.1.27.0.tar.gz
Algorithm Hash digest
SHA256 40b096fece5a00e6fea2eea181ee776bf904d13727becb51160330d05f4cc319
MD5 cd1fd367c12f746709ea710429aacad4
BLAKE2b-256 efd47750bca6aa9c8d021cc840bf1321260594e69f8e4241f0a379a2a8a7b7ab

See more details on using hashes here.

Provenance

The following attestation bundles were made for invenio_subjects_mesh_lite-2026.1.27.0.tar.gz:

Publisher: publish-to-pypi.yml on galterlibrary/invenio-subjects-mesh-lite

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

File details

Details for the file invenio_subjects_mesh_lite-2026.1.27.0-py3-none-any.whl.

File metadata

File hashes

Hashes for invenio_subjects_mesh_lite-2026.1.27.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c7242d317dd76203751f055271177e57fc172cdfbd945dae6e798a2c89e9f8cf
MD5 f9d933830fa7dabf720a73c09affb6d6
BLAKE2b-256 d50f2cbb7719607be274fc4b8d5586eae0c4c9f1c32f0138870cbca28d62ab3b

See more details on using hashes here.

Provenance

The following attestation bundles were made for invenio_subjects_mesh_lite-2026.1.27.0-py3-none-any.whl:

Publisher: publish-to-pypi.yml on galterlibrary/invenio-subjects-mesh-lite

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