Skip to main content

A mathematics BibLaTeX bibliography manager.

Project description

MathBib

MathBib is a mathematics BibLaTeX bibliography manager.

WARNING: MathBib is currently in alpha state. The API and other implementation details may change substantially!

Installation and basic usage

First, ensure that mbib is installed with

pip install mathbib

This installs the mbib command-line interface. The first useful subcommand is mbib get. For instance, running

mbib get arxiv:1212.1873

will retrieve the arxiv record at https://arxiv.org/abs/1212.1873. If you check the output, you will notice that it actually returns

@article{arxiv:1212.1873,
  author = {Hochman, Michael},
  eprint = {1337.28015},
  eprinttype = {zbl},
  journal = {Ann. Math.},
  language = {English},
  number = {2},
  pages = {773--822},
  publisher = {Annals of Mathematics},
  title = {On self-similar sets with overlaps and inverse theorems for entropy},
  volume = {180},
  year = {2014}
}

This contains more information than what can be found on arxiv! In general mbib will search multiple locations for records to build the most updated citation possible.

Generating records from command-line arguments is nice, but a much more common use case is to generate records corresponding to a file. Suppose you have a file doc.tex containing the contents

\documentclass{article}
\usepackage{biblatex}
\addbibresource{doc.bib}
\begin{document}
This document references an article \cite{arxiv:1212.1873}.
It also contains more references \cite{zbl:1251.28008, doi:10.4007/annals.2019.189.2.1}.
\printbibliography
\end{document}

Simply run

mbib generate doc.tex --out doc.bib

to build the .bib file, and compile.

Of course, it can be somewhat inconvenient to remember a large number of citation keys, especially ones that are designed to be machine-readable. One solution is to create aliases. Let's define a few:

mbib alias add Hoc2014 arxiv:1212.1873
mbib alias add HocShm2012 zbl:1251.28008
mbib alias add Shm2019 doi:10.4007/annals.2019.189.2.1

We could now instead write our file as

\documentclass{article}
\usepackage{biblatex}
\addbibresource{doc.bib}
\begin{document}
This document references an article \cite{Hoc2014}.
It also contains more references \cite{HocShm2012, Shm2019}.
\printbibliography
\end{document}

Remember to regenerate the doc.bib file with mbib generate doc.tex > doc.bib (the citation keys need to be updated), and the file will compile! Aliases also work as command line arguments anywhere a key:id is expected.

Suppose you have been working on the above TEX document for a while, and now you want to cite a specific theorem from the paper Hoc2014. Simply run

mbib file open Hoc2014

to open the PDF file associated with the resource. This will automatically download a PDF resource for the file (if mbib can find one online) and then open it. The PDF file is also saved locally, so the next time you run this command, you do not need an internet connection.

Of course, if mbib cannot find a resource for your file, you can also add one yourself.

mbib file add Hoc2014 path/to/file.pdf

Finally, if you have loaded a record but there are mistakes (for instance, improperly formatted LaTeX), you can apply local modifications which will always be applied when requesting the record. Edit the local record with, for example,

mbib file open zbl:1251.28008

There are also other features implemented: either read more below, or run mbib --help and mbib <subcommand> --help for more information.

Remote and local records

Internally, whenever you request a new record, MathBib searches a few online data repositories for the information associated with the record. Currently, the following KEY: types are supported

The requests to the various sources are cached in $XDG_CACHE_HOME/mathbib. In particular, the first search will be slow, but afterwards the request will resolve quickly.

You can see all the information collected by MathBib by running, for instance,

mbib get -r json arxiv:1212.1873

Note that MathBib also has an internal notion of record priority. Local modifications of records have the highest priority, and otherwise the priority is precisely as specified in the list above. For instance, if you run mbib show arxiv:1212.1873, your web browser will open a record on zbMATH. If you view the corresponding JSON record, you will see the zbl: entry has the highest priority.

Contributing and future improvements

MathBib is still under active development! Some planned features include:

  1. Rework the code for remote record searching and parsing.
  2. Asynchronous requests for faster record downloading.
  3. Nicer printing and viewing using rich.

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

mathbib-0.7.4.tar.gz (92.1 kB view details)

Uploaded Source

Built Distribution

mathbib-0.7.4-py3-none-any.whl (96.8 kB view details)

Uploaded Python 3

File details

Details for the file mathbib-0.7.4.tar.gz.

File metadata

  • Download URL: mathbib-0.7.4.tar.gz
  • Upload date:
  • Size: 92.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.11.4 Darwin/22.5.0

File hashes

Hashes for mathbib-0.7.4.tar.gz
Algorithm Hash digest
SHA256 cc07cdacbfaca3707d46cea0467e376f21f60250b2ebb22b2ece5c8821a7ca99
MD5 7c629fac31ea8252129e0104dbfba5f6
BLAKE2b-256 ab54541e5683819642da927466f3b3f6d27a626610a4266940fe0bba6cf1f7de

See more details on using hashes here.

File details

Details for the file mathbib-0.7.4-py3-none-any.whl.

File metadata

  • Download URL: mathbib-0.7.4-py3-none-any.whl
  • Upload date:
  • Size: 96.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.11.4 Darwin/22.5.0

File hashes

Hashes for mathbib-0.7.4-py3-none-any.whl
Algorithm Hash digest
SHA256 edf5418c2cda4473b460cc5b602ed2a81844942c692f95bfaee03020c5318600
MD5 789d4590f5998054497d1cee8c5dd9ca
BLAKE2b-256 197582a4f6b0b619e753da4fdb385207b95103eb428c8350c0bdefe2ab5c3fc8

See more details on using hashes here.

Supported by

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