Migrate your TiddlyWiki5 (Node.js version) tiddlers (.tid
files) to Markdown tiddlers (.md
files for markup plus .md.meta
files for meta information).
TiddlyWiki uses its own WikiText markup language. While this is the natural first choice when using TiddlyWiki, it's also possible writing tiddlers in Markdown using the official Markdown Plugin. Markdown has the advantage that it's used in many places (p.e. GitHub, GitLab, BitBucket, StackOverflow, Reddit) and is supported by many editors, parsers and other tools. When you often copy tiddlers (or parts of them) to other websites or when you edit/process your .tid
files with tools except TiddlyWiki itself, it might make sense to write your tiddlers in Markdown or migrate those already written in WikiText to Markdown. This is what tid2md.py
was made for.
Just clone this repository and copy/symlink tid2md.py
to a directory in your $PATH
.
For example (on Linux):
cd ~/Downloads
git clone https://github.com/MaxGyver83/tid2md.git
mkdir -p ~/.local/bin
cd ~/.local/bin
ln -s ~/Downloads/tid2md/tid2md.py
cd ~
test -f tid2md.py || PATH=~/.local/bin:"$PATH"
tid2md.py
is a Python script to be run in a terminal. It takes a list of .tid
files as input parameter. This means that it cannot be used with a single-HTML-file TiddlyWiki. It only works with a Node.js TiddlyWiki which stores every tiddler as a separate .tid
file on your disk.
⚠ Warning: This script was only tested by myself using my own tiddlers. Please test it on a copy of your wiki and check if the migrated tiddlers look like expected.
cd path/to/wiki/tiddlers
tid2md.py --delete *.tid
This will create Markdown tiddlers (consisting of a .md
and a .md.meta
file) for all WikiText tiddlers except:
- System tiddlers
- Tiddlers containing macro definitons
- Tiddlers containing at least one table
Tiddlers with tables are skipped by default because Markdown tables are lacking many features of WikiText tables (p.e. two header rows, captions, cell alignment, cell merging, ...). Use --tables
to migrate such tiddlers anyway.
The --delete
option makes the script delete the original .tid
files after a successful migration because otherwise you would end up with two versions of the same tiddler.
Run tid2md.py --help
for more options.
On my laptop, it takes about 370 ms to migrate 503 tiddlers (+ skipping 146 tiddlers).