Now that my collection of notes is becoming bigger, this starting to be a relevant tool for me.
It is not quite clear to me how the process works between amending notes/adding new notes, and getting the tool’s output back in my notes, so I have a few questions.
from you Github page I understand I can copy the python code and save that file as python obs-linkr.py, right?
I can either keep the script in a central place, or a copy of it in each vault.
the 1st time I run the script, it builds a list of note titles. If no new notes are added, and existing notes are amended, do I need to run the script each time I amend a note? If so, how do I know which notes were amended by the tool and that I therefore need to copy/paste from the clipboard to pick up tool’s output?
if what I say in point 2 is correct, it is easiest to run it once a day, or once a week, right?
if point 2 is right, the same procedure applies if new notes are added, right?
Save the file and run as python obs-linkr.py {path to vault}.
One copy of the script will work for all vaults, since the vault path is passed on the command line.
The script builds a list of note titles each time it is run - they aren’t saved. It’s really up to you how often you want to run the script, but your use case sounds too frequent. It’s designed to auto-link a block of text, not to auto-link an entire vault or work unattended. My experience was that I commonly had to review the generated output to make sure that the text wasn’t ‘overlinked’ and ambiguities that I might want to un-link for one reason or another. There is no mechanism to identify which notes need to be amended/updated.
I don’t think the script should be run according to a frequency. It should be run when there is a block of text on the clipboard that needs to be linked. It does not operate directly on any files, only on the clipboard text.
See the other responses. This is more of an ‘incremental’ tool, not a bulk editing type of tool. Spend some time with it and you’ll see that it’s probably a more simple tool than you’re making it out to be (at least for now).
Fantastic! Already making great use of this. Much appreciated
Wanted to throw in my addition to this in case others also find it useful.
I wasn’t a fan of managing a secondary alias document which I would have to manually update whenever I created new notes … so I have automated the process slightly.
Instead of adding aliases to the aliases.yml file, I add the aliases on a line directly within the note and ‘tag’ the start of the line with a unique key/string which flags that line as containing the note’s alias names.
Executing the script cycles through your vault and searches for the existence of the alias tag within all your notes and creates your aliases.yml file for direct usage with benperkins’ Auto-linking tool.
Current workflow has me periodically running the script to update the yaml file, and running the Auto-linking tool off keyboard shortcut whilst notetaking.
Example usage
While working on your note called Working from home.md you would add the alias tag :::: which identifies alternative aliases for the file, and add additional aliases you wish to link this note to.
# Working from home
:::: Remote working, Remote worker, WFH
A side effect of the pandemic is that ...
Executing the script will generate the following entry into your yml alias file:
Working from home:
- Remote working
- Remote worker
- WFH
Sincerely hope it can be a in-built function that Obsidian automatically browse file names and aliases in the vault and enable an auto-completion on bracketing when aliases found in the text, which works similarly to ‘Wikilinks’ in DEVONthink 3.
I believe that this function makes sense after having hundreds of notes in a knowledge management database.
I recently added the ability to exclude certain pages from the auto-linking process. I found that some pages were linked too often (“Work”, “Art”, etc.) and I wanted to exclude them. This is done using aliases.yml:
Note Title to Ignore:
-
- alias (optional)
The empty alias ("-") on a line by itself signals to the application that the note title shouldn’t be linked, but any aliases provided will continue to be linked to the page.
First of all big thanks for the automation. It has been a default tool for me. I wanted to know if there is a way to ignore matches to certain notes (and their aliases). Because it overwrites the aliases.html file every time it is run, It is difficult to implement the ability to exclude notes from auto-linking, added by @benperkins (Auto-Linking Tool). So, is it possible to exclude the pages from being linked right from the note?
Added a small feature to the tool called “Wikipedia mode”. If the ‘-w’ flag is provided on the command line, only the first instance of a page title (or alias) in the clipboard text will be linked.
It would make much more sense not to have to maintain an alias file at all and add aliases into each .md file. The best way to do this would be to use front matter in each file. Front matter is meant as metadata for parsers and plugins so this is the best place to put it.
Some of the reasoning behind consolidating the aliases into a single file:
Speed: Only one file needs to be opened to determine all of the aliases as opposed to cracking open every .md file in your vault in order to parse the frontmatter. Portability: If for some reason my script or Obsidian ceases to exist and you need to port your notes elsewhere, you have a bunch of orphaned YAML spread across your vault. Safety: If I can avoid opening your Markdown files, I can avoid any issues relating to data loss, privacy, etc. much more easily. Visibility: It’s much easier to see the entire scope of your aliases when they’re in one file. Fragility: If the aliases were defined in frontmatter and I decide that the format of them needs to change in the future, people are stuck updating potentially hundreds of files as opposed to just one.
Perhaps one day I’ll add the aliases to the frontmatter or provide it as an option. I suspect a plugin (hopefully an official one) may also solve the problem. For now, @Spec04 has provided a solution that works with this tool to allow you to put aliases in the frontmatter and extract them into aliases.yml.