For Converting Metadata Records into Science On Schema.Org Markup
Project description
soso
For converting dataset metadata into Science On Schema.Org markup.
Quick Start
Installation
Install from PyPI:
$ pip install soso
Metadata Conversion
To perform a conversion, specify the file path of the metadata and the desired conversion strategy. Each metadata standard corresponds to a specific strategy.
>>> from soso.main import convert
>>> r = convert(file='metadata.xml', strategy='EML')
>>> r
'{"@context": {"@vocab": "https://schema.org/", "prov": "http://www. ...}'
For a list of available strategies, please refer to the documentation of the convert function.
Adding Unmappable Properties
Some SOSO properties may not be derived from metadata records alone. In such cases, additional information can be provided via kwargs, where keys match the top level property name, and values are the property value.
For example, the url property representing the landing page URL does not exist in an EML metadata record. But this information is known to the repository hosting the dataset.
>>> kwargs = {'url': 'https://sample-data-repository.org/dataset/472032'}
>>> r = convert(file='metadata.xml', strategy='EML', **kwargs)
>>> r
'{"@context": {"@vocab": "https://schema.org/", "prov": "http://www. ...}'
It's worth noting that this kwargs approach is not limited to supplying unmappable properties; it can be utilized to override any top-level SOSO property.
Unmappable properties are listed in the strategy documentation.
Other Modifications
Any additional modifications can be made to the resulting JSON-LD string before it is used. Simply parse the string into a Python dictionary, make the necessary changes, and then convert it back to a JSON-LD string.
Shared Conversion Scripts
When data repositories use a common metadata standard and adopt shared infrastructure, such as databases containing ancillary information, a shared conversion script can be used. These scripts reliably reference the shared infrastructure to create a richer SOSO record by incorporating this additional information. Below is a list of available scripts and their usage examples:
API Reference and User Guide
The API reference and user guide are available on Read the Docs.
Code of Conduct
In the spirit of collaboration, we emphasize the importance of maintaining a respectful and inclusive environment.
See the Code of Conduct for details.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file soso-0.7.1.tar.gz.
File metadata
- Download URL: soso-0.7.1.tar.gz
- Upload date:
- Size: 100.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
348884e968748cf316a91dbed6eb053c26dff3d620137a49c74ac5aaef5636db
|
|
| MD5 |
81f734dc363c14a91285353c34506666
|
|
| BLAKE2b-256 |
243c6bde4ead2ec3650dbb1cbb39305266ddfd71bbebef3ae604ae4fa56df2cd
|
File details
Details for the file soso-0.7.1-py3-none-any.whl.
File metadata
- Download URL: soso-0.7.1-py3-none-any.whl
- Upload date:
- Size: 105.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
31eb345a0ef37605aa1b29d240fa2cad59708937135e19534f84260d11b2dfc5
|
|
| MD5 |
540873c81ef9003574222e2cfecdd3f2
|
|
| BLAKE2b-256 |
9829a0f486e6fd81b01800e512e97c19dcf2fbe918c1dd7e96ba932f802dd864
|