https://github.com/dreibh/bibtexconv
BibTeX Converter (BibTeXConv)
https://github.com/dreibh/bibtexconv
bibtex citations conversion html latex markdown references xml yaml
Last synced: 4 months ago
JSON representation
BibTeX Converter (BibTeXConv)
- Host: GitHub
- URL: https://github.com/dreibh/bibtexconv
- Owner: dreibh
- License: gpl-3.0
- Created: 2012-08-25T20:23:22.000Z (almost 14 years ago)
- Default Branch: master
- Last Pushed: 2025-12-05T14:51:29.000Z (7 months ago)
- Last Synced: 2025-12-07T19:43:44.316Z (7 months ago)
- Topics: bibtex, citations, conversion, html, latex, markdown, references, xml, yaml
- Language: TeX
- Homepage: https://www.nntb.no/~dreibh/bibtexconv/
- Size: 3.79 MB
- Stars: 6
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: ChangeLog
- License: COPYING
- Authors: AUTHORS
Awesome Lists containing this project
README
BibTeXConv
A BibTeX File Converter
https://www.nntb.no/~dreibh/bibtexconv
# 💡 What is BibTeXConv?
BibTeXConv is a BibTeX file converter which allows to export BibTeX entries to other formats, including customly defined text output. Furthermore, it provides the possibility to check URLs (including MD5, size and MIME type computations) and to verify ISBN and ISSN numbers.
# 😀 Examples
Take a look into /usr/share/doc/bibtexconv/examples/ (or corresponding path of your system) for example export scripts. The export scripts contain the commands which are read by bibtexconv from standard input.
* Check URLs of all entries in [ExampleReferences.bib](src/ExampleReferences.bib), add MD5, size and MIME type items and write the results to UpdatedReferences.bib:
```bash
bibtexconv ExampleReferences.bib \
--export-to-bibtex=UpdatedReferences.bib \
--check-urls --only-check-new-urls --non-interactive
```
* Use the export script [web-example1.export](src/web-example1.export) to export references from [ExampleReferences.bib](src/ExampleReferences.bib) to [MyPublications1.html](https://www.nntb.no/~dreibh/bibtexconv/MyPublications1.html) as XHTMLÂ 1.1. [ExampleReferences.bib](src/ExampleReferences.bib) references the script [get-author-url](src/get-author-url) and the list [authors.list](src/authors.list) to obtain the authors' website URLs:
```bash
bibtexconv ExampleReferences.bib \
MyPublications1.html
```
Note that using a script is slow, and may introduce a security issue when running export scripts from untrusted sources! The preferred way for mappings is to use mapping files, which is demonstrated by the next example.
* Use the export script [web-example2.export](src/web-example2.export) to export references from [ExampleReferences.bib](src/ExampleReferences.bib) to [MyPublications2.html](https://www.nntb.no/~dreibh/bibtexconv/MyPublications2.html) as XHTMLÂ 1.1. Unlike the example above, it reads [authors.list](src/authors.list) as a mapping file, and uses the fields *Name* and *URL* to map authors to URLs:
```bash
bibtexconv ExampleReferences.bib \
--mapping=author-url:authors.list:Name:URL \
MyPublications2.html
```
Mapping files have been introduced in BibTeXConv 2.0.
* Use export script [text-example.export](src/text-example.export) to export references from [ExampleReferences.bib](src/ExampleReferences.bib) to [MyPublications.txt](https://www.nntb.no/~dreibh/bibtexconv/MyPublications.txt) as plain text:
```bash
bibtexconv ExampleReferences.bib \
MyPublications.txt
```
* Use export script [yaml-example.export](src/yaml-example.export) to export references from [ExampleReferences.bib](src/ExampleReferences.bib) to [MyPublications.yaml](https://www.nntb.no/~dreibh/bibtexconv/MyPublications.yaml) as YAML file according to [Debian Upstream MEtadata GAthered with YAml (UMEGAYA)](https://wiki.debian.org/UpstreamMetadata) format:
* Use export script [md-example.export](src/md-example.export) to export references from [ExampleReferences.bib](src/ExampleReferences.bib) to [MyPublications.md](https://www.nntb.no/~dreibh/bibtexconv/MyPublications.md) as Markdown file with [authors.list](src/authors.list) as a mapping file for the authors to URLs:
```bash
bibtexconv ExampleReferences.bib \
--mapping=author-url:authors.list:Name:URL \
MyPublications.md
```
* Convert all references in [ExampleReferences.bib](src/ExampleReferences.bib) to XML references to be includable in IETF Internet Drafts. For each reference, an own file is generated, named with the prefix "reference." (for example: reference.Globecom2010.xml for the reference Globecom2010):
```bash
bibtexconv ExampleReferences.bib \
--export-to-separate-xmls=reference. --non-interactive
```
* Convert all references in [ExampleReferences.bib](src/ExampleReferences.bib) to BibTeX references. For each reference, an own file is generated, named with the prefix "" (here: no prefix; for example: Globecom2010.bib for the reference Globecom2010):
```bash
bibtexconv ExampleReferences.bib \
--export-to-separate-bibtexs= --non-interactive
```
* Download all references in [ExampleReferences.bib](src/ExampleReferences.bib) providing an "url" entry to directory Downloads. If the corresponding file is already existing, a download is skipped. That is, the command can be run regularly to maintain an up-to-date publications directory. Updated references (including length, type and MD5 sum of the downloaded entries) are written to UpdatedReferences.bib:
```bash
bibtexconv ExampleReferences.bib \
--export-to-bibtex=UpdatedReferences.bib \
--check-urls --store-downloads=Downloads --non-interactive
```
* Use export script [odt-example.export](src/odt-example.export) to export references from [ExampleReferences.bib](src/ExampleReferences.bib) to [MyPublications.odt](https://www.nntb.no/~dreibh/bibtexconv/MyPublications.odt) as [OpenDocument](https://www.adobe.com/uk/acrobat/resources/document-files/open-doc.html) Text (ODT), according to the template ODT file [ODT-Template.odt](src/ODT-Template.odt):
```bash
bibtexconv-odt ODT-Template.odt MyPublications.odt \
ExampleReferences.bib odt-example.export
```
ODT is the native format of [LibreOffice](https://www.libreoffice.org/)/[OpenOffice](https://www.openoffice.org/). However, LibreOffice/OpenOffice can also be used to convert it to Microsoft Word (DOCX) format, either via GUI or on the command-line to [MyPublications.docx](https://www.nntb.no/~dreibh/bibtexconv/MyPublications.docx):
```bash
soffice --convert-to docx MyPublications.odt
```
* Also take a look into the manual pages of BibTeXConv and BibTeXConv-ODT for further information and options:
```bash
man bibtexconv
man bibtexconv-odt
```
# 📦 Binary Package Installation
Please use the issue tracker at [https://github.com/dreibh/bibtexconv/issues](https://github.com/dreibh/bibtexconv/issues) to report bugs and issues!
## Ubuntu Linux
For ready-to-install Ubuntu Linux packages of BibTeXConv, see [Launchpad PPA for Thomas Dreibholz](https://launchpad.net/~dreibh/+archive/ubuntu/ppa/+packages?field.name_filter=bibtexconv&field.status_filter=published&field.series_filter=)!
```bash
sudo apt-add-repository -sy ppa:dreibh/ppa
sudo apt-get update
sudo apt-get install bibtexconv
```
## Fedora Linux
For ready-to-install Fedora Linux packages of BibTeXConv, see [COPR PPA for Thomas Dreibholz](https://copr.fedorainfracloud.org/coprs/dreibh/ppa/package/bibtexconv/)!
```bash
sudo dnf copr enable -y dreibh/ppa
sudo dnf install bibtexconv
```
## FreeBSD
For ready-to-install FreeBSD packages of BibTeXConv, it is included in the ports collection, see [FreeBSD ports tree index of benchmarks/bibtexconv/](https://cgit.freebsd.org/ports/tree/converters/bibtexconv/)!
```bash
sudo pkg install bibtexconv
```
Alternatively, to compile it from the ports sources:
```bash
cd /usr/ports/converters/bibtexconv
make
sudo make install
```
# 💾 Build from Sources
BibTeXConv is released under the [GNU General Public Licence (GPL)](https://www.gnu.org/licenses/gpl-3.0.en.html#license-text).
Please use the issue tracker at [https://github.com/dreibh/bibtexconv/issues](https://github.com/dreibh/bibtexconv/issues) to report bugs and issues!
## Development Version
The Git repository of the BibTeXConv sources can be found at [https://github.com/dreibh/bibtexconv](https://github.com/dreibh/bibtexconv):
```bash
git clone https://github.com/dreibh/bibtexconv
cd bibtexconv
sudo ci/get-dependencies --install
cmake .
make
```
Optionally, for installation to the standard paths (usually under `/usr/local`):
```bash
sudo make install
```
Note: The script [`ci/get-dependencies`](https://github.com/dreibh/bibtexconv/blob/master/ci/get-dependencies) automatically installs the build dependencies under Debian/Ubuntu Linux, Fedora Linux, and FreeBSD. For manual handling of the build dependencies, see the packaging configuration in [`debian/control`](https://github.com/dreibh/bibtexconv/blob/master/debian/control) (Debian/Ubuntu Linux), [`bibtexconv.spec`](https://github.com/dreibh/bibtexconv/blob/master/rpm/bibtexconv.spec) (Fedora Linux), and [`Makefile`](https://github.com/dreibh/bibtexconv/blob/master/freebsd/bibtexconv/Makefile) FreeBSD.
Contributions:
* Issue tracker: [https://github.com/dreibh/bibtexconv/issues](https://github.com/dreibh/bibtexconv/issues).
Please submit bug reports, issues, questions, etc. in the issue tracker!
* Pull Requests for BibTeXConv: [https://github.com/dreibh/bibtexconv/pulls](https://github.com/dreibh/bibtexconv/pulls).
Your contributions to BibTeXConv are always welcome!
* CI build tests of BibTeXConv: [https://github.com/dreibh/bibtexconv/actions](https://github.com/dreibh/bibtexconv/actions).
* Coverity Scan analysis of BibTeXConv: [https://scan.coverity.com/projects/dreibh-bibtexconv](https://scan.coverity.com/projects/dreibh-bibtexconv).
## Release Versions
See [https://www.nntb.no/~dreibh/bibtexconv/#current-stable-release](https://www.nntb.no/~dreibh/bibtexconv/#current-stable-release) for release packages!
# 🔗 Useful Links
* [BibTeX](http://www.bibtex.org/)
* [CTAN - The Comprehensive TeX Archive Network](https://www.ctan.org/)
* [Academic Integrity and Ethics](https://web.archive.org/web/20190912152938/https://www.ittc.ku.edu/~jpgs/courses/lecture-academic-integrity-display.pdf)