← 返回 Skills 市场
aipoch-ai

Anki Card Creator

作者 AIpoch · GitHub ↗ · v0.1.0 · MIT-0
cross-platform ⚠ suspicious
242
总下载
0
收藏
0
当前安装
1
版本数
在 OpenClaw 中安装
/install anki-card-creator
功能描述
Convert medical textbook content, lecture notes, and study materials into Anki flashcards using spaced repetition optimization. Supports multiple card types...
使用说明 (SKILL.md)

Anki Card Creator

Overview

Intelligent flashcard generation tool that transforms medical study materials into Anki-compatible cards optimized for long-term retention through evidence-based spaced repetition.

Key Capabilities:

  • Multi-Format Input: PDF textbooks, lecture slides, notes, web articles
  • Card Type Selection: Basic, reversible, cloze deletion, image occlusion
  • Spaced Repetition Optimization: Cards formatted for optimal review intervals
  • Automated Tagging: Hierarchical organization by subject and topic
  • Media Integration: Auto-download and embed relevant images
  • Batch Processing: Convert entire chapters or courses efficiently

When to Use

✅ Use this skill when:

  • Preparing for medical board exams (USMLE, MCAT, specialty boards)
  • Memorizing drug names, mechanisms, and side effects
  • Learning anatomy structures and relationships
  • Retaining biochemical pathways and reactions
  • Creating pathology differential diagnosis cards
  • Converting lecture notes to active recall format
  • Building comprehensive review decks from textbooks

❌ Do NOT use when:

  • Learning conceptual understanding → Use textbooks/videos first
  • Memorizing without context → Ensure comprehension before card creation
  • Creating cards for rapidly changing information → Use current resources
  • Substituting clinical experience → Cards supplement, not replace practice
  • Complex procedural skills → Use simulation or hands-on training

Integration:

  • Upstream: abstract-summarizer (textbook chapter condensation), pdf-text-extractor (content extraction)
  • Downstream: anki-sync-server (cloud backup), study-schedule-optimizer (review planning)

Core Capabilities

1. Cloze Deletion Generation

Create fill-in-the-blank cards from dense text:

from scripts.card_creator import AnkiCardCreator

creator = AnkiCardCreator()

# Generate cloze cards from text
text = """
Acute inflammation is characterized by five cardinal signs: 
redness (rubor), heat (calor), swelling (tumor), pain (dolor), 
and loss of function (functio laesa). These result from 
vasodilation, increased vascular permeability, and leukocyte 
infiltration.
"""

cards = creator.create_cloze_cards(
    text=text,
    n_cards=3,  # Generate 3 cards from this text
    difficulty="intermediate",
    tags=["Pathology", "Inflammation", "General_Pathology"]
)

# Output format (Anki-compatible)
# Card 1: "Acute inflammation is characterized by {{c1::five}} cardinal signs..."
# Card 2: "...signs: {{c1::redness}} (rubor), {{c2::heat}} (calor)..."

Cloze Strategies:

Strategy Use Case Example
Single Deletion Key facts "The {{c1::liver}} is the largest internal organ"
Multiple Deletions Lists/groups "CRAB symptoms: {{c1::Calcium}}, {{c2::Renal}}, {{c3::Anemia}}, {{c4::Bone}}"
Hierarchical Progressive detail "{{c1::Metformin}} is a {{c2::biguanide}} that {{c3::decreases hepatic glucose production}}"

2. Basic and Reversible Cards

Generate question-answer pairs:

# Create basic cards
cards = creator.create_basic_cards(
    content={
        "What is the mechanism of action of penicillin?": 
            "Inhibition of bacterial cell wall synthesis by binding to PBPs",
        "What are the major side effects of ACE inhibitors?":
            "Dry cough, hyperkalemia, angioedema, hypotension"
    },
    reversible=True,  # Create reverse cards too
    tags=["Pharmacology", "Antibiotics"]
)

Card Types:

  • Basic: Question → Answer
  • Reversible: Both directions (Q→A and A→Q)
  • Type-in: Student types answer for active recall
  • Hint Cards: Progressive disclosure with hints

3. Image Occlusion Cards

Create visual learning cards from diagrams:

# Image occlusion for anatomy
cards = creator.create_image_occlusion(
    image_path="brachial_plexus.png",
    occlude_regions=[
        {"label": "Musculocutaneous nerve", "coords": (120, 200, 200, 240)},
        {"label": "Median nerve", "coords": (300, 250, 380, 290)},
        {"label": "Ulnar nerve", "coords": (400, 280, 480, 320)}
    ],
    card_type="one_by_one"  # or "all_at_once"
)

Occlusion Types:

  • One by One: Reveal structures progressively
  • All at Once: Identify all occluded regions
  • Transparent: Hint visible through occlusion
  • Colored: Different colors for different structures

4. Smart Tagging and Organization

Automatically organize cards into logical hierarchies:

# Auto-tag based on content
cards = creator.process_textbook_chapter(
    chapter_text=pathoma_chapter,
    source="Pathoma - Hematopoiesis",
    auto_tag=True,
    tag_hierarchy=[
        "Pathoma",
        "{{chapter_name}}",
        "{{section_name}}"
    ]
)

# Results in tags like:
# Pathoma::Hematopoiesis::Red_Cell_Disorders
# Pathoma::Hematopoiesis::White_Cell_Disorders

Tagging Strategies:

  • Source-based: First Aid, Pathoma, Sketchy
  • Subject-based: Anatomy, Physiology, Pharmacology
  • Exam-based: USMLE_Step1, Step2_CK, Shelf_Exams
  • Difficulty: High_Yield, Medium_Yield, Low_Yield

Common Patterns

Pattern 1: Textbook Chapter Conversion

Scenario: Convert entire First Aid chapter to Anki deck.

# Extract and convert chapter
python scripts/main.py \
  --input first_aid_cardiology.pdf \
  --chapter "Ischemic Heart Disease" \
  --card-type cloze \
  --n-cards-per-page 3 \
  --tags "First_Aid::Cardiology::IHD" \
  --output ischemic_heart_disease.apkg

# Import directly to Anki
# File ready for import with media included

Workflow:

  1. Read chapter for understanding first
  2. Run conversion tool
  3. Review generated cards for accuracy
  4. Import to Anki
  5. Study with standard spaced repetition

Pattern 2: Drug Cards with Images

Scenario: Create comprehensive pharmacology cards.

# Generate drug cards with mechanisms
drugs = [
    {
        "name": "Metformin",
        "class": "Biguanide",
        "mechanism": "Activates AMPK, decreases hepatic gluconeogenesis",
        "indications": "Type 2 diabetes, PCOS",
        "side_effects": "GI upset, lactic acidosis (rare), B12 deficiency",
        "image": "metformin_structure.png"
    }
]

cards = creator.create_drug_cards(
    drugs=drugs,
    include_structures=True,
    include_mechanism_diagrams=True,
    tags=["Pharmacology", "Diabetes", "First_Line"]
)

Card Format:

Front: Metformin - Class?
Back: Biguanide
Tags: Pharmacology::Diabetes::First_Line

Front: Metformin - Mechanism?
Back: Activates AMPK → decreases hepatic gluconeogenesis
Image: [mechanism diagram]
Tags: Pharmacology::Diabetes::Mechanism

Front: Metformin - Side effects?
Back: GI upset, lactic acidosis (rare), B12 deficiency
Tags: Pharmacology::Diabetes::Side_Effects

Pattern 3: Pathology Differential Cards

Scenario: Create cards for differential diagnosis practice.

# Differential diagnosis cards
cards = creator.create_differential_cards(
    condition="Cough with hemoptysis",
    differentials=[
        {"diagnosis": "Lung cancer", "key_features": "Smoker, weight loss, mass on CT"},
        {"diagnosis": "TB", "key_features": "Immigrant, night sweats, cavitary lesion"},
        {"diagnosis": "PE", "key_features": "Sudden onset, tachypnea, D-dimer elevated"},
        {"diagnosis": "Bronchiectasis", "key_features": "Chronic cough, purulent sputum, dilated airways"}
    ],
    card_type="compare_contrast"
)

Card Types:

  • Feature → Diagnosis: "Smoker + hemoptysis + weight loss → ?"
  • Diagnosis → Features: "Lung cancer presentation?"
  • Compare: "Differentiate lung cancer vs TB"

Pattern 4: Lecture Notes to Cards

Scenario: Convert professor's lecture slides to study cards.

# Process lecture PDF
python scripts/main.py \
  --input lecture_slides.pdf \
  --source "Dr_Smith_Cardiology_Lecture_5" \
  --card-type mixed \
  --extract-images \
  --auto-tag \
  --output cardiology_lecture_5.apkg

# Review and edit in Anki
# Delete low-yield cards
# Add personal mnemonics

Post-Processing Tips:

  • Delete obvious or overly simple cards
  • Merge redundant cards
  • Add personal memory hooks
  • Suspend low-yield topics

Complete Workflow Example

Building comprehensive USMLE Step 1 deck:

# Step 1: Process multiple sources
python scripts/main.py \
  --input first_aid_pathology.pdf \
  --source "First_Aid_2024" \
  --card-type cloze \
  --tags "First_Aid::Pathology" \
  --output fa_pathology.apkg

python scripts/main.py \
  --input sketchy_pharm.pdf \
  --source "Sketchy_Pharm" \
  --card-type basic \
  --include-images \
  --tags "Sketchy::Pharm" \
  --output sketchy_pharm.apkg

# Step 2: Merge decks
python scripts/main.py \
  --merge fa_pathology.apkg sketchy_pharm.apkg \
  --output usmle_step1_master.apkg

# Step 3: Add leech tags for difficult cards
python scripts/main.py \
  --input usmle_step1_master.apkg \
  --tag-leeches \
  --leech-threshold 8 \
  --output usmle_step1_tagged.apkg

Python API:

from scripts.card_creator import AnkiCardCreator
from scripts.importers import PDFImporter

# Initialize
creator = AnkiCardCreator()
importer = PDFImporter()

# Import and process textbook
content = importer.import_pdf(
    path="robbins_pathologic_basis_of_disease.pdf",
    pages="150-200",  # Inflammation chapter
    extract_images=True
)

# Create cloze cards
cards = creator.create_cloze_cards(
    text=content.text,
    images=content.images,
    n_cards=50,
    difficulty="advanced",
    tags=["Robbins", "General_Pathology", "Inflammation"]
)

# Add image occlusion for diagrams
for diagram in content.diagrams:
    occlusion_cards = creator.create_image_occlusion(
        image=diagram,
        auto_detect_labels=True
    )
    cards.extend(occlusion_cards)

# Export Anki package
creator.export_apkg(
    cards=cards,
    deck_name="Robbins_Inflammation",
    output_path="robbins_inflammation.apkg"
)

print(f"Created {len(cards)} cards ready for Anki import")

Quality Checklist

Card Quality:

  • One fact per card (atomicity)
  • Clear, unambiguous questions
  • Answers specific and complete
  • Cloze deletions don't give away answer
  • Images high resolution and relevant
  • Tags hierarchical and consistent

Educational Value:

  • Cards test high-yield information
  • Difficulty appropriate for level
  • Connections between related concepts
  • Clinical context included where relevant
  • No duplicate or near-duplicate cards

Technical Quality:

  • Valid Anki format (import tested)
  • Media files properly linked
  • UTF-8 encoding for special characters
  • CSS styling readable on mobile
  • Card types appropriate for content

Before Study:

  • CRITICAL: Review cards for accuracy
  • CRITICAL: Delete cards for mastered material
  • Personalize with own mnemonics
  • Adjust card order if needed
  • Set appropriate daily review limits

Common Pitfalls

Content Issues:

  • Too much information → "Cramming" cards with multiple facts

    • ✅ One concept per card; break complex topics into multiple cards
  • Memorization without understanding → Memorizing without context

    • ✅ Include "why" and clinical significance
  • Outdated information → Old guidelines or disproven theories

    • ✅ Verify against current textbooks and guidelines

Card Design Issues:

  • Ambiguous clozes → "The {{c1::liver}} produces {{c2::bile}}" (which one is being asked?)

    • ✅ Clear question: "The liver produces ?" or "What organ produces bile?"
  • Overlapping cards → Testing same fact multiple ways

    • ✅ Merge redundant cards; each fact tested once optimally
  • Recognition vs. recall → Cards too easy (recognition only)

    • ✅ Use cloze deletions and type-in cards for active recall

Study Strategy Issues:

  • Too many new cards → 100+ new cards/day leads to burnout

    • ✅ Sustainable pace: 20-30 new cards/day
  • No review of missed cards → Ignoring leeches

    • ✅ Tag and review difficult cards separately
  • Passive card creation → Making cards without studying

    • ✅ Create cards for immediate use; don't build massive backlog

References

Available in references/ directory:

  • anki_format_spec.md - Anki .apkg file format specifications
  • spaced_repetition_principles.md - Evidence-based SRS guidelines
  • card_design_best_practices.md - Effective flashcard design
  • usmle_high_yield_facts.md - High-yield content for boards
  • image_sources.md - Open-access medical images
  • tagging_conventions.md - Standardized tag hierarchies

Scripts

Located in scripts/ directory:

  • main.py - CLI interface for card creation
  • card_creator.py - Core card generation engine
  • cloze_generator.py - Cloze deletion algorithms
  • image_occlusion.py - Visual card creation
  • pdf_importer.py - Textbook and slide import
  • tag_manager.py - Automated tagging system
  • media_handler.py - Image download and optimization
  • anki_exporter.py - .apkg file generation

Limitations

  • Context Dependency: May miss nuanced explanations without full context
  • Image Licensing: Must verify copyright for extracted images
  • Complex Diagrams: Simple occlusion may not capture complex relationships
  • Personalization: Generic cards lack personal memory hooks
  • Volume Control: Easy to create too many cards; requires curation
  • Active Learning: Cards supplement but don't replace active problem-solving

Parameters

Parameter Type Default Required Description
--input, -i string - No Input text file with Q&A pairs
--output, -o string anki_cards.txt No Output file (Anki TSV format)
--drug flag - No Create drug information card
--anatomy flag - No Create anatomy card
--name string - No Drug or structure name
--mechanism string - No Mechanism of action (for drug cards)
--indications string - No Clinical indications (for drug cards)
--side-effects string - No Side effects (for drug cards)
--location string - No Anatomical location (for anatomy cards)
--function string - No Function (for anatomy cards)

Usage

Basic Usage

# Create drug card
python scripts/main.py --drug --name "Metformin" --mechanism "Decreases hepatic glucose production" --indications "Type 2 diabetes" --output metformin.txt

# Create anatomy card
python scripts/main.py --anatomy --name "Coronary arteries" --location "Surface of heart" --function "Supply oxygenated blood to myocardium" --output coronary.txt

# Parse Q&A file
python scripts/main.py --input questions.txt --output deck.txt

Input File Format

Q: What is the mechanism of action of Metformin?
A: Decreases hepatic glucose production, increases insulin sensitivity

Q: Which artery supplies the left ventricle?
A: Left anterior descending artery (LAD)

Risk Assessment

Risk Indicator Assessment Level
Code Execution Python script executed locally Low
Network Access No external API calls Low
File System Access Read input file, write to output file Low
Instruction Tampering Standard prompt guidelines Low
Data Exposure Output saved only to specified location Low

Security Checklist

  • No hardcoded credentials or API keys
  • No unauthorized file system access
  • Output does not expose sensitive information
  • Prompt injection protections in place
  • Input validation for file paths
  • Output directory restricted to workspace
  • Script execution in sandboxed environment

Prerequisites

# Python 3.7+
# No additional packages required (uses standard library)

Evaluation Criteria

Success Metrics

  • Successfully creates Anki-compatible TSV files
  • Supports drug and anatomy card types
  • Parses Q&A files correctly
  • Generates valid HTML formatting

Test Cases

  1. Drug Card: Create Metformin card → Valid TSV output with formatted front/back
  2. Anatomy Card: Create coronary artery card → Valid TSV with location and function
  3. File Parse: Parse Q&A text file → Multiple cards generated

Lifecycle Status

  • Current Stage: Draft
  • Next Review Date: 2026-03-06
  • Known Issues: None
  • Planned Improvements:
    • Add Cloze deletion support
    • Support image inclusion
    • Add .apkg export format

🧠 Study Tip: The best flashcard is one you'll actually review. Create cards for material you genuinely need to memorize, and keep the daily review load sustainable. Quality over quantity—better to deeply learn 1000 cards than superficially memorize 5000.

安全使用建议
This skill's documentation promises many advanced features but the bundled code only supports simple local Q/A parsing and TSV export. Before installing or using it for real study materials: (1) ask the author for the missing implementation (PDF/text extractors, image occlusion, media download, APKG export) or for an explanation of why SKILL.md exceeds the code; (2) verify any code that would download or access external URLs — none is present now, but confirm before accepting network access; (3) do not feed sensitive or copyrighted medical PDFs into this skill until you confirm where data may be sent or stored; (4) if you plan to use it, test in an isolated environment and review/modify scripts/main.py to match the intended workflow (or replace with verified tools); (5) request corrected examples (the SKILL.md imports scripts.card_creator but the file is scripts/main.py). These mismatches suggest the skill is incomplete or misdocumented rather than actively malicious, but you should treat it as untrusted until the gaps are resolved.
功能分析
Type: OpenClaw Skill Name: anki-card-creator Version: 0.1.0 The skill bundle provides a functional Python script (scripts/main.py) for generating Anki flashcards from text input or command-line arguments. While the documentation (SKILL.md) describes advanced features like PDF extraction and image occlusion that are not implemented in the provided code, the existing logic is safe, uses only standard libraries, and lacks any indicators of malicious intent, data exfiltration, or unauthorized execution. The script includes basic sanitization for its TSV output and operates strictly within the stated purpose of educational tool creation.
能力评估
Purpose & Capability
The skill advertises PDF/text extraction, cloze-generation, image occlusion, media download/embedding, batch processing, and integrations. The shipped code (scripts/main.py) only performs simple Q/A parsing, creates a few hard-coded card types, and writes a TSV. There are no PDF or image-handling routines, no network/media download, no Anki .apkg export, and the SKILL.md examples import from scripts.card_creator while the repo contains scripts/main.py — capability claims are disproportionate to the actual code.
Instruction Scope
SKILL.md instructs use of tools and workflows (PDF chapter conversion, image occlusion, auto-tagging, integration with other skills) that require reading files, downloading media, and invoking other components. The included script only reads local text files and writes a TSV; it cannot perform the described PDF extraction, image occlusion, or external integrations. The instructions give broad discretion (allowed-tools includes Bash and Read/Write) but the implementation does not constrain or implement those behaviors, creating a gap between 'what to do' and 'what actually runs'.
Install Mechanism
No install spec is provided and the package is effectively instruction + a small Python script. Nothing is downloaded or installed automatically and there are no external install URLs, so installation risk is low.
Credentials
The skill declares no required environment variables or credentials and the code does not read environment variables or request secrets. Credential requests are proportionate (none) to the stated functionality.
Persistence & Privilege
The skill is not forced-always, and it does not request elevated platform persistence. Default autonomy (model invocation allowed) is normal and not combined with other red flags here.
如何使用
  1. 确保已安装 OpenClaw(本地或 Docker 部署)
  2. 在对话框中输入安装命令:/install anki-card-creator
  3. 安装完成后,直接呼叫该 Skill 的名称或使用 /anki-card-creator 触发
  4. 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v0.1.0
- Initial release of Anki Card Creator for medical study materials. - Supports conversion from textbooks, lecture notes, and web content to Anki flashcards. - Generates cloze, basic, reversible, and image occlusion card types. - Includes automated tagging, hierarchical deck organization, and spaced repetition optimization. - Integrates media such as images into cards. - Enables batch processing for efficient creation of large decks.
元数据
Slug anki-card-creator
版本 0.1.0
许可证 MIT-0
累计安装 0
当前安装数 0
历史版本数 1
常见问题

Anki Card Creator 是什么?

Convert medical textbook content, lecture notes, and study materials into Anki flashcards using spaced repetition optimization. Supports multiple card types... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 242 次。

如何安装 Anki Card Creator?

在 OpenClaw 或 Claude Code 对话框中运行命令「/install anki-card-creator」即可一键安装,无需额外配置。

Anki Card Creator 是免费的吗?

是的,Anki Card Creator 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。

Anki Card Creator 支持哪些平台?

Anki Card Creator 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。

谁开发了 Anki Card Creator?

由 AIpoch(@aipoch-ai)开发并维护,当前版本 v0.1.0。

💬 留言讨论