A Python wrapper for the Semantic Scholar Dataset API that provides easy access to academic papers, citations, and related data
Project description
Semantic Scholar Dataset API Wrapper
A Python wrapper for the Semantic Scholar Dataset API that provides easy access to academic papers, citations, and related data.
Description
This library provides a simple interface to interact with the Semantic Scholar Dataset API, allowing you to:
- Access various academic datasets (papers, citations, authors, etc.)
- Download dataset releases
- Get diffs between releases
- Manage large dataset downloads efficiently
Installation
pip install semanticscholar-datasetapi
Requirements
- Python 3.7+
- requests
Basic Usage
from semanticscholar_datasetapi import SemanticScholarDataset
import os
# Initialize the client with your API key
api_key = os.getenv("SEMANTIC_SCHOLAR_API_KEY")
client = SemanticScholarDataset(api_key=api_key)
# List available datasets
datasets = client.get_available_datasets()
print(datasets)
# Get latest release information
releases = client.get_available_releases()
print(releases)
# Download latest release of a specific dataset
client.download_latest_release(datasetname="papers", save_dir="downloads")
# Get diffs between releases
client.download_diffs(
start_release_id="2024-12-31",
end_release_id="latest",
datasetname="papers",
save_dir="diffs"
)
Available Datasets
The API provides access to the following datasets:
- abstracts
- authors
- citations
- embeddings-specter_v1
- embeddings-specter_v2
- paper-ids
- papers
- publication-venues
- s2orc
- tldrs
API Reference
Main Methods
SemanticScholarDataset(api_key: Optional[str] = None)
Initialize the API client with an optional API key.
api_key: API key for accessing the Semantic Scholar Dataset API. Required for most operations.
get_available_releases() -> list
Get a list of all available dataset releases.
get_available_datasets() -> list
Get a list of all available datasets.
get_download_urls_from_release(datasetname: Optional[str] = None, release_id: str = "latest") -> Dict[str, Any]
Get download URLs for a specific release of a dataset.
datasetname: Name of the dataset to get URLs forrelease_id: ID of the release (defaults to "latest")
get_download_urls_from_diffs(start_release_id: Optional[str], end_release_id: str = "latest", datasetname: Optional[str]) -> Dict[str, Any]
Get download URLs for differences between two releases.
start_release_id: Starting release IDend_release_id: Ending release ID (defaults to "latest")datasetname: Name of the dataset to get diff URLs for
download_latest_release(datasetname: Optional[str] = None, save_dir: Optional[str] = None, range: Optional[range] = None) -> None
Download the latest release of a specific dataset.
datasetname: Name of the dataset to downloadsave_dir: Directory to save downloaded files (defaults to current directory)range: Optional range of indices to download from the list of files
download_past_release(release_id: str, datasetname: Optional[str] = None, save_dir: Optional[str] = None, range: Optional[range] = None) -> None
Download a specific past release of a dataset.
release_id: ID of the release to downloaddatasetname: Name of the dataset to downloadsave_dir: Directory to save downloaded files (defaults to current directory)range: Optional range of indices to download from the list of files
download_diffs(start_release_id: str, end_release_id: str, datasetname: Optional[str] = None, save_dir: Optional[str] = None) -> None
Download the differences between two releases of a dataset.
start_release_id: Starting release IDend_release_id: Ending release IDdatasetname: Name of the dataset to download diffs forsave_dir: Directory to save downloaded files (defaults to current directory)
Error Handling
The library includes comprehensive error handling for:
- Invalid dataset names
- Missing API keys
- Network errors
- Invalid release IDs
File Naming
Downloaded files follow these naming patterns:
- Latest release:
{datasetname}_latest_{index}.json.gz - Past release:
{datasetname}_{release_id}_{index}.json.gz - Diffs:
- Updates:
{datasetname}_{from_release}_{to_release}_update_{index}.json.gz - Deletes:
{datasetname}_{from_release}_{to_release}_delete_{index}.json.gz
- Updates:
Environment Variables
SEMANTIC_SCHOLAR_API_KEY: Your API key for the Semantic Scholar Dataset API
License
This project is licensed under the MIT License - see the LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Acknowledgments
- Semantic Scholar for providing the Dataset API
- The academic community for maintaining and contributing to the datasets
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 semanticscholar_datasetapi-0.1.1.tar.gz.
File metadata
- Download URL: semanticscholar_datasetapi-0.1.1.tar.gz
- Upload date:
- Size: 6.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.9.21
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a4380f3f46402812a8056edbf6acbac499655ab75df6060e7df2e2e62e863097
|
|
| MD5 |
7d0fa36c8cbdaceba718f87cb68ee94a
|
|
| BLAKE2b-256 |
94d2a3d0762ba0f2c173c0c768af9abeab2aea860b9e44960ac3b669dc275a98
|
File details
Details for the file semanticscholar_datasetapi-0.1.1-py3-none-any.whl.
File metadata
- Download URL: semanticscholar_datasetapi-0.1.1-py3-none-any.whl
- Upload date:
- Size: 7.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.9.21
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e62648e0bbd7c2df2a014e0e9120dfec0ebb2bb83a9d7ae88a8852e66f86dc53
|
|
| MD5 |
4adf96eff27352421d84726a276fde63
|
|
| BLAKE2b-256 |
222c4ad6672946fb067ef7e5046c2b5a74f1e79482db7f23ce22697f4e408819
|