Crate obsidian_parser

Source
Expand description

obsidian-parser - Blazingly fast Rust library for parsing and analyzing Obsidian vaults

Provides idiomatic APIs for:

  • Parsing individual Obsidian notes with frontmatter properties
  • Analyzing entire vaults as knowledge graphs
  • Extracting semantic relationships between notes

§Key Features

  • 🛡️ 100% Safe Rust - Strictly forbids unsafe code (#![forbid(unsafe_code)])
  • High Performance - Parses 1000 notes in <3ms
  • 🕸️ Knowledge Graphs - Built-in petgraph integration for graph analysis (requires [petgraph] feature)

§Usage

Add to Cargo.toml:

[dependencies]
obsidian-parser = { version = "0.3", features = ["petgraph", "rayon"] }

§Examples

§Basic Parsing

use obsidian_parser::prelude::*;
use serde::Deserialize;

// Parse single file with `HashMap`
let note_hashmap = ObFileInMemory::from_file_default("note.md").unwrap();

println!("Content: {}", note_hashmap.content().unwrap());
println!("Properties: {:#?}", note_hashmap.properties().unwrap().unwrap());

// Parse single file with custom struct
#[derive(Clone, Deserialize)]
struct NoteProperties {
    created: String,
    tags: Vec<String>,
    priority: u8,
}

let note_with_serde: ObFileInMemory<NoteProperties> = ObFileInMemory::from_file("note.md").unwrap();

§Vault Analysis

use obsidian_parser::prelude::*;

// Load entire vault
let vault = Vault::open_default("/path/to/vault").unwrap();

// Check for duplicate note names
if !vault.check_unique_note_name() {
    eprintln!("Duplicate note names detected!");
}

// Access parsed files
for file in vault.files {
  println!("Note: {:?}", file.path());
}

§Graph Analysis (requires [petgraph] feature)

#[cfg(feature = "petgraph")]
{
    use obsidian_parser::prelude::*;
    use petgraph::dot::{Dot, Config};

    let vault = Vault::open_default("/path/to/vault").unwrap();
    let graph = vault.get_digraph().unwrap();
     
    // Export to Graphviz format
    println!("{:?}", Dot::with_config(&graph, &[Config::EdgeNoLabel]));
     
    // Find most connected note
    let most_connected = graph.node_indices()
        .max_by_key(|n| graph.edges(*n).count())
        .unwrap();
    println!("Knowledge hub: {}", graph[most_connected]);
}

§Performance

Optimized for large vaults:

  • 🚀 1000 files parsed in 2.7ms (avg)
  • 💾 Peak memory: 900KB per 1000 notes

Parallel processing via Rayon (enable [rayon] feature)

Modules§

error
Error handling for Obsidian vault parsing operations
obfile
Represents an Obsidian note file with frontmatter properties and content
prelude
All prelude
vault
Obsidian vault parsing and analysis