eb8dbf66a1
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
3.1 KiB
3.1 KiB
name, kind, lang, domain, version, purity, signature, description, tags, uses_functions, uses_types, returns, returns_optional, error_type, imports, params, output, tested, tests, test_file_path, file_path
| name | kind | lang | domain | version | purity | signature | description | tags | uses_functions | uses_types | returns | returns_optional | error_type | imports | params | output | tested | tests | test_file_path | file_path | |||||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| search_obsidian_notes | function | py | obsidian | 1.0.0 | impure | search_obsidian_notes(vault_dir: str, query: str, in_body: bool = True, in_frontmatter: bool = True) -> list | Busca un substring (case-insensitive) en todas las notas .md de un vault de Obsidian, excluyendo .obsidian/ y .trash/. Devuelve por nota las lineas que contienen el query con su numero de linea. Los flags in_body/in_frontmatter acotan donde buscar. |
|
|
false | error_go_core |
|
|
lista de dicts {path, matches} (uno por nota con coincidencias), ordenada por path; cada match es {line, text} con numero de linea 1-based relativo al archivo completo | false | python/functions/obsidian/search_obsidian_notes.py |
Ejemplo
from obsidian import search_obsidian_notes
# Buscar "presupuesto" en todo el vault (frontmatter + cuerpo)
hits = search_obsidian_notes("/home/enmanuel/Obsidian/Finanzas", "presupuesto")
for h in hits:
print(h["path"])
for m in h["matches"]:
print(f" L{m['line']}: {m['text']}")
# Solo en el cuerpo, ignorando el frontmatter
solo_cuerpo = search_obsidian_notes(
"/home/enmanuel/Obsidian/Finanzas", "TODO", in_frontmatter=False
)
Cuando usarla
Cuando necesites un grep de un solo paso sobre un vault de Obsidian: encontrar en que notas aparece un termino y en que lineas, antes de abrir/editar. Util para auditar tags, localizar referencias o construir un indice de busqueda.
Gotchas
- Impura: lee el filesystem. Lanza
ValueErrorsiqueryes vacio,FileNotFoundErrorsi el vault no existe yNotADirectoryErrorsi no es un directorio. - Exclusion obligatoria:
.obsidian/y.trash/se podan del recorrido; su contenido nunca se busca ni aparece en resultados. - Coste en vaults grandes: abre y lee CADA nota
.mdlinea a linea. En vaults pesados comoNotasDeObsidian(~554M) esto recorre todo el contenido en memoria por archivo; puede tardar. Acota el vault o pre-filtra conlist_obsidian_notessi necesitas rendimiento. - Numeros de linea: son 1-based y relativos al archivo completo (incluyen las lineas del frontmatter
---), de modo que mapean directamente sobre el archivo en disco aunque se busque solo en cuerpo o solo en frontmatter. - La delimitacion frontmatter/cuerpo se calcula con
parse_obsidian_frontmatter; si la nota no tiene frontmatter valido, todo se considera cuerpo. - Archivos con encoding invalido se leen con
errors="replace".