CtrlK
BlogDocsLog inGet started
Tessl Logo

jobe-skills/ebook-library

Use when the user asks about a Calibre ebook library or book collection: find books, search metadata or full text in EPUB/AZW3 files, or locate book paths via Calibre databases.

100

1.35x

Quality

100%

Does it follow best practices?

Impact

100%

1.35x

Average score across 3 eval scenarios

Overview
Skills
Evals
Files

find_books.pyscripts/

#!/usr/bin/env python3
import sqlite3
import json
import argparse
import os
import sys


def search(db_path, query, limit=50):
    if not os.path.exists(db_path):
        print(json.dumps({"error": f"DB not found: {db_path}"}))
        return 2
    conn = sqlite3.connect(db_path)
    cur = conn.cursor()
    q = f"%{query.lower()}%"
    exact = query.lower()
    try:
        # Simple search on title or author
        sql = (
            "SELECT b.id, b.title, group_concat(a.name, ', ') AS authors "
            "FROM books b LEFT JOIN books_authors_link bal ON bal.book=b.id "
            "LEFT JOIN authors a ON a.id=bal.author "
            "WHERE lower(b.title) LIKE ? OR lower(a.name) LIKE ? "
            "GROUP BY b.id "
            "ORDER BY CASE "
            "WHEN lower(b.title) = ? THEN 0 "
            "WHEN lower(a.name) = ? THEN 1 "
            "ELSE 2 END, b.title "
            "LIMIT ?"
        )
        cur.execute(sql, (q, q, exact, exact, limit))
        rows = cur.fetchall()
        out = []
        for r in rows:
            out.append({"id": int(r[0]), "title": r[1], "authors": r[2]})
        print(json.dumps(out, indent=2, ensure_ascii=False))
        return 0
    except Exception as e:
        print(json.dumps({"error": str(e)}))
        return 3

if __name__ == '__main__':
    p = argparse.ArgumentParser(description='Find books by keyword in Calibre metadata')
    p.add_argument('--db-path', required=True, help='Path to metadata.db')
    p.add_argument('--query', required=True, help='Search term')
    p.add_argument('--limit', type=int, default=50)
    args = p.parse_args()
    sys.exit(search(args.db_path, args.query, args.limit))

Install with Tessl CLI

npx tessl i jobe-skills/ebook-library

SKILL.md

tile.json