Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Bibliographic data #284

Open
1 of 4 tasks
rufuspollock opened this issue Jul 8, 2018 · 7 comments
Open
1 of 4 tasks

Bibliographic data #284

rufuspollock opened this issue Jul 8, 2018 · 7 comments

Comments

@rufuspollock
Copy link
Member

Awesome page in progress at: https://datahub.io/collections/bibliographic-data

What we Cover

Datasets we want to cover:

  • Author metadata
  • Article metadata
  • Book metadata (bonus points if FRBR-like)

Tasks

State of play

I compiled a detailed spreadsheet (as of 2016) of the state of play here:

https://docs.google.com/spreadsheets/d/1Sx-MKTkAhpaB3VHiouYDgMQcH81mKwQtaK2-BXYbKkE/edit#gid=0

Context

These are the kind of questions / user stories I had

  • Could one build an "open" Google Scholar or an open "OCLC"
  • If i wanted to build a "lookup" service for my reference manager what API could I use and what is the license on the data?
  • Where can I find open (or just free) bibliography data
  • Where can I find open (or just free) bibliography online services or APIs

User stories:

  • I come across a book or article and i want to quickly get full biblio info for storing in a blog post or an article i am writing
  • I come across a book or article title and want to look it up
  • Ditto and i want to auto-save into my local bibliography

Aim of research

  • Identify existing databases or services providing substantial bibliographic data
  • Can partition between books and papers as they are different
  • Classify in key ways e.g. open or not etc
@miku
Copy link

miku commented Jul 15, 2018

CrossRef - has API but no official regular bulk dump

We have been working with the crossref API (for a search infrastructure project) since early 2015 and we found it to be excellent to work with concerning usability and documentation. We were interested in complete dumps as well, so we implemented a monthly harvest as part of our metadata gathering and processing infrastructure, which is based on luigi.

The basic operation is as follows:

Use a filter (we used deposit, but should switch to from-deposit-date or similar) to request all items for the last month. Also, use the cursor mechanism, which is the way to extract a large number of documents fast (plug: solrdump is a generic fast SOLR document exporter).

You end up with some directory full of JSON files.

$ tree -sh 
...
├── [8.4G]  begin-2018-02-01-end-2018-03-01-filter-deposit.ldj
├── [7.5G]  begin-2018-03-01-end-2018-04-01-filter-deposit.ldj
├── [ 12G]  begin-2018-04-01-end-2018-05-01-filter-deposit.ldj
├── [9.4G]  begin-2018-05-01-end-2018-06-01-filter-deposit.ldj
└── [6.4G]  begin-2018-06-01-end-2018-07-01-filter-deposit.ldj

This is how the monthly harvest sizes developed over the years:

Zoomed in a bit (from 2015):

Now, seeing all these files as a single data set, there are quite some duplicates (redeposited files, through publisher updates or API changes). It would not be too complicated to run some additional data store, which could hold only the most recent record (by overwriting records via DOI).

We opted for another approach, which allows us to not have to maintain an external data store and still have only the latest version of each DOI at hand: We just iterate over all records and keep the last. This currently means iterating over 400G of JSON, but that's actually not that bad. After a few sketches, the functionality went into a custom command line tool, span-crossref-snapshot.

That tools is a bit ugly (implementation-wise), as it tries hard to be fast (parallel compression, advanced sort flags, custom fast filter tool with awk fallback, and so on). It is quite fast and despite the awkward bits quite reliable.

// Given a single file with crossref works API messages, create a potentially
// smaller file, which contains only the most recent version of each document.
//
// Works in a three-stage, two-pass fashion: (1) extract, (2) identify, (3) extract.
// Performance data point (30M compressed records, 11m33.871s):
//
// 2017/07/24 18:26:10 stage 1: 8m13.799431646s
// 2017/07/24 18:26:55 stage 2: 45.746997314s
// 2017/07/24 18:29:30 stage 3: 2m34.23537293s

In the end, we do have a file crossref.ldj.gz which is about 40G in size and currently contains 97494426 records.

anuveyatsu referenced this issue in datasets/core-datasets Jul 17, 2018
@anuveyatsu
Copy link
Member

I've created bibliographic-data page available at https://datahub.io/awesome/bibliographic-data with initial content about DBLP data.

@rufuspollock
Copy link
Member Author

@miku this is really awesome info - thank-you. Are you hosting the data anywhere - can you share it?

@miku
Copy link

miku commented Sep 6, 2018

Are you hosting the data anywhere - can you share it?

No, at the moment, we only use the crossref data for building an index for a couple of institutions.

@glgoose glgoose transferred this issue from datasets/core-datasets Nov 28, 2019
@miku
Copy link

miku commented Jan 31, 2020

FWIW: In addition to sources already listed in the spreadsheet, a few more sources may be found here at https://archive.org/details/ia_biblio_metadata.

@rufuspollock
Copy link
Member Author

@miku very useful - thank-you!

@miku
Copy link

miku commented Nov 3, 2022

There's an upload of this dataset at: https://archive.org/details/crossref-2022-11-02 (139M docs).

@rufuspollock rufuspollock moved this to Published in Data Curation Mar 8, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: Published
Development

No branches or pull requests

3 participants