Skip to main content
Glama

MCP Server Anki

MCP TypeScript AnkiConnect

δΈ­ζ–‡ζ–‡ζ‘£ | English

A Model Context Protocol (MCP) server that bridges Anki with AI tools, enabling intelligent flashcard management and learning assistance.

πŸ’‘ Compatibility: This server works with any MCP-compatible AI tool including Claude Code, Cline, Zed AI, and more. We use Claude Code as an example in this documentation, but the setup process is similar for other tools.

🌟 Features

  • πŸ“š Deck Management: Get deck lists, view deck statistics

  • πŸ” Card Search: Search cards using Anki's advanced query syntax

  • βž• Smart Creation: Create and manage Anki cards with AI assistance

  • ✏️ Card Editing: Update existing card fields and content

  • πŸ—‘οΈ Card Deletion: Delete unwanted cards and notes

  • πŸ“Š Data Analysis: Get learning statistics and progress information

  • πŸ”§ Template Management: View and use different note types

πŸ“‹ Prerequisites

  1. Anki Desktop - Download Anki

  2. AnkiConnect Plugin - Install in Anki (Code: 2055492159)

  3. Node.js - Version 16 or higher

  4. MCP-compatible AI Tool - Such as:

πŸš€ Quick Start

1. Install AnkiConnect

In Anki:

  1. Tools β†’ Add-ons β†’ Get Add-ons

  2. Enter code: 2055492159

  3. Restart Anki

2. Configure Your MCP Client

The following examples use Claude Code, but the configuration is similar for other MCP-compatible tools.

Option A: Using Command Line

# For Claude Code
claude mcp add anki -- npx mcp-server-anki

# For other tools, consult their documentation for the equivalent command

Option B: Manual Configuration

Add the server to your MCP client's configuration file:

{
  "mcp": {
    "servers": {
      "anki": {
        "command": "npx",
        "args": ["mcp-server-anki"]
      }
    }
  }
}

πŸ“– Usage Guide

Basic Workflow

  1. Start Anki - Ensure Anki is running with AnkiConnect enabled

  2. Start MCP Server - Automatically started by Claude Code

  3. Use AI Tools - Interact with Anki through Claude Code

Example Conversations

User: Show me the learning progress for my "English Vocabulary" deck

Claude: I'll check the statistics for your "English Vocabulary" deck...
[Calls get_deck_stats tool]

User: Create a new English word card for "ephemeral"

Claude: I'll create this word card for you...
[Calls add_note tool]

πŸ› οΈ Available Tools

Tool Name

Description

Parameters

get_deck_names

Get all deck names

None

get_cards_in_deck

Get cards from a specific deck

deckName

get_deck_stats

Get deck statistics

deckName

search_cards

Search cards

query

add_note

Add new note

deckName, modelName, fields, tags

update_note

Update existing note fields

noteId, fields

get_note_info

Get detailed note information

noteId

delete_notes

Delete one or more notes

noteIds

get_models

Get all note types

None

get_model_fields

Get note type fields

modelName

πŸ—οΈ Project Structure

mcp-server-anki/
β”œβ”€β”€ src/
β”‚   β”œβ”€β”€ index.ts           # MCP server entry point
β”‚   β”œβ”€β”€ ankiConnect.ts      # AnkiConnect API client
β”‚   └── tools/              # MCP tool definitions
β”‚       β”œβ”€β”€ deckTools.ts    # Deck-related tools
β”‚       β”œβ”€β”€ cardTools.ts    # Card-related tools
β”‚       └── noteTools.ts    # Note-related tools
β”œβ”€β”€ dist/                   # Compiled JavaScript
β”œβ”€β”€ package.json
β”œβ”€β”€ tsconfig.json
└── README.md

πŸ”§ Development

Build Commands

# Development mode (watch for changes)
npm run dev

# Production build
npm run build

Architecture

Claude Code (MCP Client) ←→ Anki MCP Server ←→ AnkiConnect ←→ Anki Desktop

πŸ“ API Documentation

get_deck_names

Get a list of all deck names.

Returns:

["Default", "English Vocabulary", "Programming"]

search_cards(query)

Search cards using Anki query syntax.

Parameters:

  • query: Anki query string (e.g., deck:English is:due)

Query Syntax Examples:

  • deck:DeckName - Specific deck

  • tag:TagName - By tag

  • is:due - Due cards

  • is:new - New cards

  • added:7 - Cards added in last 7 days

add_note

Add a new note to Anki.

Parameters:

  • deckName: Target deck name

  • modelName: Note type (e.g., "Basic", "Cloze")

  • fields: Field content object

  • tags: Tag array (optional)

Example:

{
  "deckName": "English Vocabulary",
  "modelName": "Basic",
  "fields": {
    "Front": "ephemeral",
    "Back": "lasting for a very short time"
  },
  "tags": ["vocabulary", "adjective"]
}

update_note

Update fields of an existing note.

Parameters:

  • noteId: The ID of the note to update

  • fields: Object with field names and new values

Example:

{
  "noteId": 1234567890,
  "fields": {
    "Back": "lasting for an extremely short time"
  }
}

get_note_info

Get detailed information about a specific note.

Parameters:

  • noteId: The ID of the note to query

Returns:

{
  "noteId": 1234567890,
  "modelName": "Basic",
  "fields": {
    "Front": "ephemeral",
    "Back": "lasting for a very short time"
  },
  "tags": ["vocabulary", "adjective"]
}

delete_notes

Delete one or more notes.

Parameters:

  • noteIds: Array of note IDs to delete

Example:

{
  "noteIds": [1234567890, 9876543210]
}

πŸ”§ Building from Source

If you want to contribute or customize the server:

# Clone the repository
git clone https://github.com/here-tunan/mcp-server-anki.git
cd mcp-server-anki

# Install dependencies
npm install

# Build TypeScript
npm run build

To use your local build with Claude Code, configure it with:

{
  "mcp": {
    "servers": {
      "anki": {
        "command": "node",
        "args": ["/path/to/mcp-server-anki/dist/index.js"]
      }
    }
  }
}

🀝 Contributing

Issues and Pull Requests are welcome!

πŸ“„ License

Apache License

❓ FAQ

Q: AnkiConnect connection failed?

A: Ensure Anki is running and AnkiConnect plugin is installed and enabled. Default port is 8765.

Q: How to customize note types?

A: After creating custom note types in Anki, use get_models and get_model_fields tools to view available fields.

Q: Mobile support?

A: Currently only supports desktop Anki due to AnkiConnect dependency.


Made with ❀️ for Anki learners and AI enthusiasts

Install Server
A
license - permissive license
A
quality
C
maintenance

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/here-tunan/mcp-server-anki'

If you have feedback or need assistance with the MCP directory API, please join our Discord server