Skip to main content

A Model Context Protocol server for generating HTML and Word quiz files from Markdown content

Project description

chinese README in here:

README_ZH.md

MCP Quiz Generator

A quiz generator server based on Model Context Protocol (MCP) that generates Markdown questions according to requirements and converts them into HTML and Word format quiz files.

Features

  • 🎯 Support for multiple question types: single choice, multiple choice, true/false, short answer
  • 📄 Generate interactive HTML quiz files
  • 📝 Generate Word format quiz files (including answer key and student versions)
  • 🔧 Based on MCP protocol, integrates with editors like Cursor, VSCode
  • ⚡ Fast dependency management using uv

Supported Question Formats

Single Choice Questions

1. Which testing automation frameworks has MaxSoft developed?
    - [x] IntelliAPI  (Correct answer marked with [x])
    - [ ] WebBot      (Incorrect answer marked with [ ])
    - [ ] Gauge
    - [ ] Selenium

Multiple Choice Questions

2. Which testing automation frameworks has MaxSoft developed?
    - [x] IntelliAPI  (Multiple correct answers all marked with [x])
    - [x] WebBot      
    - [ ] Gauge       (Incorrect answer marked with [ ])
    - [ ] Selenium

True/False Questions

3. MaxSoft is a software company.
    - (x) True        (Correct answer marked with (x))
    - ( ) False       (Incorrect answer marked with ( ))

Short Answer Questions

4. Who is the co-founder of MaxSoft?
    - R:= Osanda      (Answer marked with R:= followed by correct answer)

Installation and Setup

Prerequisites

  • Python 3.10 or higher
  • uv package manager

Configuring MCP in Cursor/VSCode

Method 1: Using uvx (Recommended)

  1. Create MCP configuration file:

    In Cursor/VSCode, open MCP settings and add the following configuration:

    {
      "mcpServers": {
        "mcp-quiz-generator": {
          "command": "uvx",
          "args": ["mcp-quiz-generator" , "--output-folder" , "{output-folder-path}"]
        }
      }
    }
    

Note: Replace {output-folder-path} with the storage path for generated files.

Method 2: Using Python directly

  1. First ensure dependencies are installed:

    uv sync
    
  2. Add to MCP configuration:

    {
      "mcpServers": {
        "mcp-quiz-generator": {
          "command": "/path/to/mcp-quiz-generator/.venv/bin/python",
          "args": ["run", "mcp-quiz-generator" , "--output-folder" , "{output-folder-path}"]
        }
      }
    }
    

Note: Replace {output-folder-path} with the storage path for generated files.

Tool Parameters

  • markdown_content: Quiz content in Markdown format
  • format_type: Output format
    • "html": Generate HTML file only
    • "word": Generate Word file only
    • "both": Generate both HTML and Word files (default)
  • custom_filename: Custom filename (optional, without extension)

Output Files

If the --output-folder parameter is not used, generated files will be saved in the data/ directory by default:

  • HTML file: Interactive quiz with online answering support

  • image-20250826102712411

  • Word files:

    image-20250826102752443

    • *_quiz.docx: Student version (without answers)
    • *_answer_key.docx: Teacher version (with answers and markings)

Project Structure

mcp-quiz-generator/
├── src/
│   └── quiz_mcp/
│       ├── __init__.py
│       ├── server.py          # MCP server main file
│       └── app/               # Application module directory
│           ├── extensions/    # Markdown extensions
│           └── static/        # Static resource files
├── data/                      # Output file directory (default)
├── pyproject.toml            # Project configuration
├── uv.lock                   # Dependency lock file
└── README.md                 # Project documentation

Troubleshooting

Common Issues

  1. uv command not found

    • Ensure uv is properly installed and added to PATH
    • Restart terminal or editor
  2. MCP server connection failed

    • Check if paths in configuration file are correct
    • Ensure virtual environment is created: uv sync
    • Check editor's MCP logs for detailed error information
  3. Generated file format is incorrect

    • Check if Markdown content follows specified format
    • Ensure options have correct indentation (4 spaces)

--output-folder Parameter Description

The --output-folder parameter is used to specify the output directory for generated quiz files.

Syntax:

uv run mcp-quiz-generator --output-folder <directory-path>

Parameter Description:

  • <directory-path>: Specifies the directory path for output files
  • Default value: data (if this parameter is not specified, files will be saved to data/ directory)
  • If the specified directory doesn't exist, the program will create it automatically

Usage Examples:

# Use default output directory (data/)
uv run mcp-quiz-generator

# Specify custom output directory
uv run mcp-quiz-generator --output-folder ./my_quizzes

# Specify absolute path
uv run mcp-quiz-generator --output-folder /home/user/quiz_files

# Specify relative path
uv run mcp-quiz-generator --output-folder ../output

Usage Example

Complete Conversation Example: Generating Prompt Engineering Quiz

Here's a complete usage example showing how to generate a quiz about Prompt Engineering through an AI assistant:

User Question:

Q: give me some quiz about Prompt Engineering then generate word and html file

AI Assistant Response:

Of course, I can generate a quiz about Prompt Engineering for you. Here are a few questions. I will then use a tool to generate the Word and HTML files.

Here is the quiz content:

#### Single Choice Questions

1. What is a core principle of prompt engineering?
   -  Using the shortest prompt possible.
   -  Providing clear and specific instructions.
   -  Using complex vocabulary.
   -  Always asking for a single-word answer.

#### Multiple Choice Questions

1. Which of the following are common prompt engineering techniques?
   -  Zero-shot prompting
   -  Few-shot prompting
   -  Chain-of-thought prompting
   -  Random word generation

#### True/False Questions

1. "Few-shot prompting" involves giving the model several examples before asking the final question.
   - (x) True
   - ( ) False

#### Short Answer Questions

1. What technique encourages a model to explain its reasoning step-by-step before giving a final answer?
   - R:= Chain-of-thought prompting

Now, let me generate the files for you.

(mcp-quiz-generator : generate_quiz completed)

I have generated the quiz files for you in both Word and HTML formats. Here are the files that have been created:

- **HTML (Interactive Quiz):** `{output-folder-path}\Prompt_Engineering_Quiz.html`
- **Word (Quiz for students):** `{output-folder-path}\Prompt_Engineering_Quiz_quiz.docx`
- **Word (Answer Key):** `{output-folder-path}\Prompt_Engineering_Quiz_answer_key.docx`

Let me know if you need anything else

License

MIT License

Contributing

Issues and Pull Requests are welcome!

Reference

https://github.com/osandadeshan/markdown-quiz-generator

Changelog

v0.1.0

  • Initial release
  • Support for basic quiz generation functionality
  • Support for HTML and Word format output
  • MCP protocol integration

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mcp_quiz_generator-0.1.0.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_quiz_generator-0.1.0-py3-none-any.whl (5.2 kB view details)

Uploaded Python 3

File details

Details for the file mcp_quiz_generator-0.1.0.tar.gz.

File metadata

  • Download URL: mcp_quiz_generator-0.1.0.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.18

File hashes

Hashes for mcp_quiz_generator-0.1.0.tar.gz
Algorithm Hash digest
SHA256 52944d5d9cb08f0062d2778fb8634c8820a6cf8b0e1af5c417adca907607e873
MD5 f178d939ae96a42cb1f91bb2f1a4716c
BLAKE2b-256 312922345ff8f26826975ef129305d74c33ac863383fb26b813f97c5954806df

See more details on using hashes here.

File details

Details for the file mcp_quiz_generator-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for mcp_quiz_generator-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6c90dea7a2492b1ae5634132d81f85024378358cbcfcb056625145789472250b
MD5 f86112b61f78990d258a68cf94795115
BLAKE2b-256 7cb0977dc8b88b3a2e5414d055311e9049fc02929c77b6266a3e900342e092bc

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page