Skip to main content

Bibliography management tool.

Project description

PyBibthèque

Command line program to organize and manage a bibliography or references.

Notes

Connects to mongodb database via a URI. The details are in the config at .config/bibtheque.toml Run tests with pytest

Still need to come up with a universal id system. I like doi and isbn but that doesn't work when a paper or book doesn't have that (like for a manual entry). I'm considering making a hash to id idea but I'm not sure if that's the best. I need to investigate particular hashes.

I need to implement the side of bibtheque that outputs bibtex strings to a bib file with correct ids for use in an article

Fill out the argument parser help doc.

Integrate tags and notes in the cli.py

running

pip install -e <path> to install and run

bibtex

https://www.bibtex.com/format/

setup

library |- database.json |- raw/ |- annotated/ |- .gitignore

initialize

bibtheque init

  • make library folder and folder structure
  • make database.json
  • make default config at .config/bibtheque.yml
  • make .gitignore with raw/ and annotated/ in it

insert files

insert files with insert -f ? (f flag for file?)

original filename is stored file is renamed according to uuid given to it and moved when entry is called, original file is returned (uuid.pdf renamed original.pdf)

versioning

use git for database.json and config

BibTeX

entry types

article book booklet conference (same as inproceedings) inbook incollection inproceedings manual mastersthesis misc phdthesis proceedings techreport unpublished

required and optional fields

type

  • required
  • optional

article

  • author, title, journal, year, volume
  • number, pages, month, doi, note, key

book

  • author or editor, title, publisher, year
  • volume or number, series, address, edition, month, note, key, url

booklet

  • title
  • author, howpublished, address, month, year, note, key

conference (see inproceedings)

inbook

  • author or editor, title, chapter or pages, publisher, year
  • volume or number, series, type, address, edition, month, note, key

incollection

  • author, title, booktitle, publisher, year
  • editor, volume or number, series, type, chapter, pages, address, edition, month, note, key

inproceedings

  • author, title, booktitle, year
  • editor, volume or number, series, pages, address, month, organization, publisher, note, key

manual

  • title
  • author, organization, address, edition, month, year, note, key

mastersthesis

  • author, title, school, year
  • type, address, month, note, key

misc

  • author, title, howpublished, month, year, note, key

phdthesis

  • author, title, school, year
  • type, address, month, note, key

proceedings

  • title, year
  • editor, volume or number, series, address, month, publisher

techreport

  • author, title, institution, year
  • type, number, address, month, note, key

unpublished

  • author, title, note
  • month, year, key

fields

address annote author booktitle Email chapter crossref doi edition editor howpublished institution journal key month note number organization pages publisher school series title type volume year

database

all bibtex fields read flag tags organization tags synopsis annotations raw_path annotated_path

doc_dict

  • bib_dict (dict) -> doc_dict['bib']
    • fields (str)
  • read flag (bool)
  • tags (list) -> including project labels
  • synopsis (str)
  • notes (str)
  • path_dict (dict) -> doc_dict['path']
    • raw_path (str)
    • annotated_path (str)

database

  • type
    • alphabetical order of required fields

Connect:

mongosh "mongodb://144.44.44.44" --username root --password pass
doc = {}

doc['bib'] = bib_dict

if file_text:
    doc['file_text'] = file_text

if file_path:
    doc['file_path'] = file_path

if annotated_path:
    doc['annotated_path'] = annotated_path

# if len(tags) > 0:
doc['tags'] = tags

if notes:
    doc['notes'] = notes

if synopsis:
    doc['synopsis'] = synopsis

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

bibtheque-0.1.6.tar.gz (18.0 kB view details)

Uploaded Source

Built Distribution

bibtheque-0.1.6-py3-none-any.whl (19.9 kB view details)

Uploaded Python 3

File details

Details for the file bibtheque-0.1.6.tar.gz.

File metadata

  • Download URL: bibtheque-0.1.6.tar.gz
  • Upload date:
  • Size: 18.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for bibtheque-0.1.6.tar.gz
Algorithm Hash digest
SHA256 aa112a1fd69f15ac4102998da0c2457659688fff30266b5f6eca372ecc2156ec
MD5 b9291562bebf7d2f20d39bcc43e2e7de
BLAKE2b-256 9e508bb0038daec75b261c4fc362836d86b353cf08c50fbf6878948fd82ea237

See more details on using hashes here.

File details

Details for the file bibtheque-0.1.6-py3-none-any.whl.

File metadata

  • Download URL: bibtheque-0.1.6-py3-none-any.whl
  • Upload date:
  • Size: 19.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for bibtheque-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 447312afe0865e7336a00a19989ddfb0f8b70dee5b134fc26965e8d9f06f265b
MD5 3b00cd4f5136cd6a022cd63a95cb96bf
BLAKE2b-256 649e8a821ef30eec416200e8ffac9ec59e4dea2df1c691b3ba4a506b8ededca1

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