# Krafna
[](https://github.com/7sedam7/krafna/actions/workflows/release.yml)
Krafna is a terminal-based alternative to Obsidian's Dataview plugin, allowing you to query your Markdown files using standard SQL syntax.
## Features
- Query Markdown files in a directory using SQL-like syntax
- Support for frontmatter data extraction
- Flexible output formats (TSV and JSON)
- Compatible with Neovim plugin [Perec](https://github.com/7sedam7/perec.nvim)
## Installation
### Cargo (Recommended)
```bash
cargo install krafna
```
### Homebrew
```bash
brew tap 7sedam7/krafna
brew install krafna
```
## Usage
### Basic Query
```bash
krafna "SELECT title, tags FROM FRONTMATTER_DATA('~/.notes')"
```
### Find Files
```bash
krafna --find ~/.notes
```
### Output as JSON
```bash
krafna "SELECT * FROM FRONTMATTER_DATA('~/.notes')" --json
```
### Include Specific Fields
```bash
krafna "SELECT * FROM FRONTMATTER_DATA('~/.notes')" --include-fields title,tags
```
## Syntax Differences from Dataview
- Uses standard SQL syntax
- Selection of "table" to query is done with `FROM FRONTMATTER_DATA("<path>")` function, that makes all md files within <path> a row (their frontmatter data). Currently no other sources and no JOINs. I plan to add them later.
- Not all Dataview features are implemented yet
## Neovim Integration
Use with the [Perec](https://github.com/7sedam7/perec) Neovim plugin for seamless integration.
## Author
[7sedam7](https://github.com/7sedam7)