Media Cloud API Client Library
Project description
MediaCloud Python API Client
This is a python client for accessing the MediaCloud API v4. This allows you to perform cross-platform searches and also browse our collection/source/feed directory.
Usage
First sign up for an API key. Then
pip install mediacloud
Check CHANGELOG.md
for a detailed history of changes.
Examples
Take a look at the test in the mediacloud/test/
module for more detailed examples.
Count Stories Matching a Query
import mediacloud.api
US_NATIONAL_COLLECTION = 34412234
mc_search = mediacloud.api.SearchApi(YOUR_MC_API_KEY)
all_stories = []
pagination_token = None
more_stories = True
while more_stories:
page, pagination_token = mc_search.story_list('robots', start_date= , end_date= collection_ids=[US_NATIONAL_COLLECTION])
all_stories += page
more_stories = pagination_token is not None
print(f"Retrived {len(all_stories)} matching stories")
Page Through Stories Matching a Query
import mediacloud.api
INDIA_NATIONAL_COLLECTION = 34412118
mc_search = mediacloud.api.SearchApi(YOUR_MC_API_KEY)
all_stories = []
pagination_token = None
more_stories = True
while more_stories:
page, pagination_token = mc_search.story_list('modi AND biden', collection_ids=[INDIA_NATIONAL_COLLECTION],
pagination_token=pagination_token)
all_stories += page
more_stories = pagination_token is not None
print(f"Retrived {len(all_stories)} matching stories")
Fetch all Sources in a Collection
import mediacloud.api
INDIA_NATIONAL_COLLECTION = 34412118
SOURCES_PER_PAGE = 100 # the number of sources retrieved per page
mc_directory = mediacloud.api.DirectoryApi(YOUR_MC_API_KEY)
sources = []
offset = 0 # offset for paging through
while True:
# grab a page of sources in the collection
response = mc_directory.source_list(collection_id=INDIA_NATIONAL_COLLECTION, limit=SOURCES_PER_PAGE, offset=offset)
# add it to our running list of all the sources in the collection
sources += response['results']
# if there is no next page then we're done so bail out
if response['next'] is None:
break
# otherwise setup to fetch the next page of sources
offset += len(response['results'])
print("India National Collection has {} sources".format(len(sources)))
Development
If you are interested in adding code to this module, first clone the GitHub repository.
Installing
flit install
pre-commit install
Testing
pytest
Distributing a New Version
- Run
pytest
to make sure all the test pass - Update the version number in
pyproject.toml
- Make a brief note in the
CHANGELOG.md
about what changes - Commit changes, and tag comimt with version number
- Push to main
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
File details
Details for the file mediacloud-4.3.0.tar.gz
.
File metadata
- Download URL: mediacloud-4.3.0.tar.gz
- Upload date:
- Size: 17.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0069068c9f0e3c24399fefa9ca7188728ee514c22509a5cf082b875bfad9bb78 |
|
MD5 | cc09012ee7e974e470c5c7a58aa1485e |
|
BLAKE2b-256 | 9585a272968417ccc4bd3d4692c3eb8e97571e61b0ffd4f9ebe8e4b395d9b764 |
Provenance
The following attestation bundles were made for mediacloud-4.3.0.tar.gz
:
Publisher:
publish-to-pypi.yml
on mediacloud/api-client
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
mediacloud-4.3.0.tar.gz
- Subject digest:
0069068c9f0e3c24399fefa9ca7188728ee514c22509a5cf082b875bfad9bb78
- Sigstore transparency entry: 147374647
- Sigstore integration time:
- Predicate type:
File details
Details for the file mediacloud-4.3.0-py3-none-any.whl
.
File metadata
- Download URL: mediacloud-4.3.0-py3-none-any.whl
- Upload date:
- Size: 19.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2af4dea344009c47c9b9d4ec6c42dad741cd8c988946bc06d1df11e4fee8aff8 |
|
MD5 | 3bac78a8970d08a78e04a21bd35291fc |
|
BLAKE2b-256 | 6c84346e343a0e5d559b3089a17ece0fb0515bc1a4332a4e04b73022bf44b013 |
Provenance
The following attestation bundles were made for mediacloud-4.3.0-py3-none-any.whl
:
Publisher:
publish-to-pypi.yml
on mediacloud/api-client
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
mediacloud-4.3.0-py3-none-any.whl
- Subject digest:
2af4dea344009c47c9b9d4ec6c42dad741cd8c988946bc06d1df11e4fee8aff8
- Sigstore transparency entry: 147374649
- Sigstore integration time:
- Predicate type: