Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/notnews/archive_news_cc

Closed Caption Transcripts of News Videos from archive.org 2014--2023
https://github.com/notnews/archive_news_cc

archive-org closed-caption-transcripts closed-captions news news-videos transcript transcripts

Last synced: about 2 months ago
JSON representation

Closed Caption Transcripts of News Videos from archive.org 2014--2023

Awesome Lists containing this project

README

        

## Closed Captions of News Videos from Archive.org

The repository provides scripts for downloading the data, and link to two datasets that were built using the scripts:

* [Scripts](https://github.com/notnews/archive_news_cc#downloading-the-data-from-archiveorg)
* [Data](https://github.com/notnews/archive_news_cc#data)

-------------

### Downloading the Data from Archive.org

Download closed caption transcripts of nearly 1.3M news shows from [http://archive.org](http://archive.org).

There are three steps to downloading the transcripts:

1. We start by searching [https://archive.org/advancedsearch.php](https://archive.org/advancedsearch.php) with collection `collection:"tvarchive"`. This gets us unique identifiers for each of the news shows. An identifier is a simple string that combines channel_name, show_name, time, and date. The current final list of identifiers (2009--Nov. 2017) is posted [here](data/search.csv).

2. Next, we use the identifier to build a URL where the metadata file and HTML file with the closed captions is posted. The general base URL is http://archive.org/download followed by the identifier.

3. The third script parses the downloaded metadata and HTML closed caption files and creates a CSV along with the meta data.

For instance, we will go http://archive.org/download/CSPAN_20090604_230000 for identifier `CSPAN_20090604_230000` And from http://archive.org/download/CSPAN_20090604_230000/CSPAN_20090604_230000_meta.xml, we read the link http://archive.org/details/CSPAN_20090604_230000, from which we get the text from HTML file. We also store the meta data from the META XML file.

#### Scripts

1. **Get Show Identifiers**
- [Get Identifiers For Each Show (Channel, Show, Date, Time)](scripts/get_news_identifiers.py)
- Produces [data/search.csv](data/search.csv)

2. **Download Metadata and HTML Files**
- [Download the Metadata and HTML Files](scripts/scrape_archive_org.py)
- Saves the metadata and HTML files to two separate folders specified in `--meta` and `--html` respectively. The default folder names are `meta` and `html` respectively.

3. **Parse Metadata and HTML Files**
- [Parses metadata and HTML Files and Saves to a CSV](scripts/parse_archive.py)
- Produces a CSV. [Here's an example](data/archive-out.csv)

#### Running the Scripts

1. Get all TV Archive identifiers from archive.org.

```
python get_news_identifiers.py -o ../data/search.csv
```

2. Download metadata and HTML files for all the shows in the [sample input file](data/search-test.csv)

```
python scrape_archive_org.py ../data/search-test.csv
```

This will create two directories `meta` and `html` by default in the same folder as where the script is. We have included the first [25 metadata](data/meta/) and first 25 [html files](data/html/).

You can change the folder for `meta` by using the `--meta` flag. To change the directory for `html`, use the `--html` flag and specify the new directory. For instance,

```
python scrape_archive_org.py --meta meta-foxnews --html html-foxnews ../data/search-test.csv
```

Use `-c/--compress` option to store and parse the downloaded files in compression format (GZip).

3. Parse and extract meta fields and text from [sample metadata](data/meta) and [HTML files](data/html).

```
python parse_archive.py ../data/search-test.csv
```

A [sample output file](data/archive-out.csv).

### Data

The data are hosted on [Harvard Dataverse](https://dataverse.harvard.edu/dataset.xhtml?persistentId=doi:10.7910/DVN/OAJJHI)

**Dataset Summary:**

1. **500k Dataset from 2014:**
- CSV: `archive-cc-2014.csv.xza*` (2.7 GB, split into 2GB files)
- HTML: `html-2014.7za*` (10.4 GB, split into 2GB files)

2. **860k Dataset from 2017:**
- CSV: `archive-cc-2017.csv.gza*` (10.6 GB, split into 2GB files)
- HTML: `html-2017.tar.gza*` (20.2 GB, split into 2GB files)
- Meta: `meta-2017.tar.gza*` (2.6 GB, split into 2GB files)

3. **917k Dataset from 2022:**
- CSV: `archive-cc-2022.csv.gza*` (12.6 GB, split into 2GB files)
- HTML: `html-2022.tar.gza*` (41.1 GB, split into 2GB files)
- Meta: `meta-2022.tar.gz` (2.1 GB)

4. **179k Dataset from 2023:**
- CSV: `archive-cc-2023.csv.gz` (1.7 GB)
- HTML: `html-2023.tar.gza*` (7.3 GB, split into 2GB files)
- Meta: `meta-2023.tar.gz` (317 MB)

Please note that the file sizes and splitting information mentioned above are approximate.

### License

We are releasing the scripts under the [MIT License](https://opensource.org/licenses/MIT).

### Suggested Citation

Please credit Internet Archive for the data.

If you wanted to refer to this particular corpus so that the research is reproducible, you can cite it as:
```
archive.org TV News Closed Caption Corpus. Laohaprapanon, Suriyan and Gaurav Sood. 2017. https://github.com/notnews/archive_news_cc/
```