Skip to main content

Write a journal

Project description

Build Status PyPI PyPI - Python Version Code style: black

jrnl

jrnl is a personal journal management application.

Usage

Setup

Set up your journal by printing out a config file, like so:

jrnl --setup

and fill out the path to the root of your journal.

Using jrnl

Open up today's journal entry with

jrnl

which will open up today's journal entry in your favourite text editor.

Using jrnl grep

jrnl also comes with a grep wrapper which you can invoke as follows:

jrnl grep [OPTIONS] PATTERN

where OPTIONS are normal grep options.

Advanced usage

Timestamps

You can generate a timestamp before opening the entry by using the -t flag:

jrnl -t

or you can have timestamps always written by specifying so in your config file.

Negative date offsets

You can open up another date's journal entry by specifying a date as an argument. One way of doing this is with negative date offsets: for example, to open up yesterday's journal run

jrnl -1

Fuzzy dates

Another way to pass a date to jrnl is with a date string (wrapped in quotes if it contains spaces). jrnl uses dateutil's fuzzy date parser to parse the strings you pass in, which lets you specify dates like "Nov 7 2017":

jrnl "Nov 7 2017"

dateutil can do more: for example, specifying the 4th of the current month's date with

jrnl 4

Accessing the latest existing entry

You can open the latest existing journal entry with HEAD like so:

jrnl HEAD

Aliases for HEAD are LAST and LATEST—all of which are case insensitive.

Accessing an existing entry's ancestor

You can access the ancestor of an existing entry with suffixes ^ or ~N (for the Nth ancestor). These work almost identically to the same suffixes in git. For example, to find the fifth last existing journal enty, you can do

jrnl HEAD~5

These suffixes can be stacked and combined in any way you like.

Accessing the closest existing entry to a given date

To access the closest existing journal entry for a given date, add the @ suffix to the date. For example, to find the closest entry to 2017-01-01, you'd do

jrnl @2017-01-01

Opening multiple entries

To open up multiple entries simply pass in multiple date arguments. For example,

jrnl -7 "Jan 01 2016" 20180504

will open entries for a week ago, 2018-01-01, and 2018-05-04.

Extending a date past midnight

If in your config file you have

hours_past_midnight_included_in_date: N

where N is some postive integer; then for a given date, at 0N:00 or earlier, jrnl will open up the day before's journal entry.

:confused: What? Here's the motivation:

When it's 02:00, we're likely to refer to this time as night, rather than morning. Likewise, you might want a journal chunk (for lack of a better term) written at 02:00 to be in the same entry as chunks from (technically) the previous day. If you do want such a thing, you can specify a time in your config file: at any time before this specified time (inclusive), jrnl will open up the day before's journal entry.

Journal structure

Right now you're constrained to having a journal structure like so:

journal_root/
journal_root/2017/
journal_root/2017/2017-07-05.txt
journal_root/2017/2017-09-01.txt

and if you want to use all the features you're going to need to be okay with ISO 8601-based timestamps:

2017-09-01
21:06

You'd write stuff here.

22:30

And more stuff here.

How do I install this?

sudo pip3 install jrnl-mw

or just run the run_jrnl.py script directly.

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

jrnl_mw-1.4.0.tar.gz (12.2 kB view details)

Uploaded Source

Built Distribution

jrnl_mw-1.4.0-py3-none-any.whl (16.0 kB view details)

Uploaded Python 3

File details

Details for the file jrnl_mw-1.4.0.tar.gz.

File metadata

  • Download URL: jrnl_mw-1.4.0.tar.gz
  • Upload date:
  • Size: 12.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.3

File hashes

Hashes for jrnl_mw-1.4.0.tar.gz
Algorithm Hash digest
SHA256 66a8b4d3f4902fa83f7aea3ef235a21c8d04eb882b5a6fa79b1746f80f52dee7
MD5 e4f76245bc21bfe82587f6b403af1498
BLAKE2b-256 6b26148ab9a2b559bcede9148d60ef4b4a92fc8aa4631a3644539a39792bfd8c

See more details on using hashes here.

File details

Details for the file jrnl_mw-1.4.0-py3-none-any.whl.

File metadata

  • Download URL: jrnl_mw-1.4.0-py3-none-any.whl
  • Upload date:
  • Size: 16.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.3

File hashes

Hashes for jrnl_mw-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a953946dd742431faa4b3d25f7b080f7c61834e7711c0071b9f644d1a365ca9d
MD5 803a3e2bb2e49daa67248b4362838f7c
BLAKE2b-256 3ee64179cd65c366a101771f26145458e34437aafdd8c4593d5438d2708b79c0

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