Skip to main content

A set of tools to support downloading GDELT data

Project description

Loading GDELT data into MongoDB

This is a set of programs for loading the GDELT 2.0 data set into MongoDB.

Quick Start

Install the latest version of Python from python.org. You need at least version 3.6 for this program. Many versions of Python that come pre-installed are only 2.7. This version will not work.

Now install gdelttools

pip install gdelttools

Now get the master file of all the GDELT files.

gdeltloader --master

This will generate a file named something like masterfilelist.txt

Downloading the master data set

To download the master data set associated with GDELT (the export files) you can combine these steps:

gdeltloader --master --download --overwrite

This will get the master file, parse it, extract the list of CSV files and unzip them. the full GDELT 2.0 database runs to several terabytes of data so this is not recommend.

The overwrite argument ruthlessly overwrites all files with extreme prejudice. Without it the gdeltloader script will attempt to reuse the files you have already downloaded. As each file is unique this may save time if you need to re-download some files.

To limit the amount you download you can specify --last to define how many files worth of data you want to download:

gdeltloader --master --download --overwrite --last 20

This command will download the most recent 20 files worth of data. Note that a file is a triplet of export, mentions and gkg data. If you only want one you should specify a --filter. Without the filter a command like the above will actually download 60 files.

GDELT 2.0 Encoding and Structure

The GDELT dataset is a large dataset of news events that is updated in real-time. GDELT stands for Global Database of Events Location and Tone. The format of records in a GDELT data is defined by the GDELT 2.0 Codebook

Each record uses an encoding method called CAMEO coding which is defined by the CAMEO Codebook.

Once you understand the GDELT recording structure and the CAMEO encoding you will be able to decode a record. To fully decode a record you may need the TABARI dictionaries from which the CAMEO encoding is derived.

How to download GDELT 2.0 data

The gdeltloader script can download cameo data and unzip the files so that they can be loaded into MongoDB.

usage: gdeltloader [-h] [--master] [--update] [--database DATABASE] [--collection COLLECTION]
  [--local LOCAL] [--overwrite] [--download] [--metadata]
  [--filter {all,gkg,mentions,export}] [--last LAST] [--version]

options:
  -h, --help            show this help message and exit
  --master              GDELT master file [False]
  --update              GDELT update file [False]
  --database DATABASE   Default database for loading [GDELT]
  --collection COLLECTION
                        Default collection for loading [events_csv]
  --local LOCAL         load data from local list of zips
  --overwrite           Overwrite files when they exist already
  --download            download zip files from master or local file
  --metadata            grab meta data files
  --filter {all,gkg,mentions,export}
                        download a subset of the data, the default is all data [export, mentions gkg, all]
  --last LAST           how many recent files to download default : [0] implies all files
  --version             show program's version number and exit

Version: 0.07b1 More info : https://github.com/jdrumgoole/gdelttools

Here is how to download the last 5 hours of GDELT data.

gdeltloader --master --update --download --last 20

This command will only download the export files for the last 20 15-minute blocks, which are the files we are interested in.

How to import downloaded data into MongoDB

Now import the CSV files with mongoimport.

There is a mongoimport.sh script in the gdelttools repo which is already configured with the right arguments. There is also a corresponding field file, gdelt_field_file.ff which this script uses to ensure correct type mappings.

To run:

sh mongoimport.sh --uri "<YOUR-MONGODB-CONNECTION-STRING>"

This will upload all the CSV files in the current working directory.

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

gdelttools-0.7b2.tar.gz (17.0 kB view details)

Uploaded Source

Built Distribution

gdelttools-0.7b2-py3-none-any.whl (16.1 kB view details)

Uploaded Python 3

File details

Details for the file gdelttools-0.7b2.tar.gz.

File metadata

  • Download URL: gdelttools-0.7b2.tar.gz
  • Upload date:
  • Size: 17.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.2

File hashes

Hashes for gdelttools-0.7b2.tar.gz
Algorithm Hash digest
SHA256 e7d6319cd025cc53fe907b97c01c1048b14be326748b5d167246392743e09521
MD5 ec649b41afec3e455d251a542c19551f
BLAKE2b-256 5baaed7cf3bb4d58b7e30d87e7bef8e4958e0b57a47b938c6c19c02fbefef785

See more details on using hashes here.

File details

Details for the file gdelttools-0.7b2-py3-none-any.whl.

File metadata

  • Download URL: gdelttools-0.7b2-py3-none-any.whl
  • Upload date:
  • Size: 16.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.2

File hashes

Hashes for gdelttools-0.7b2-py3-none-any.whl
Algorithm Hash digest
SHA256 83113557a25f229a93baf09bde2e8baf7dab907ab2ad031531926cd3d338abb1
MD5 6a9edeb9028b9fb8f06210fb68328218
BLAKE2b-256 6eede0f863799d83d8445cd106ab3bfcf300470f7c5210bbbed64f060da64ebf

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page