| from mcp.server.fastmcp import FastMCP |
| import json |
|
|
| mcp = FastMCP("text-processor") |
|
|
| @mcp.tool() |
| def analyze_text(text: str) -> str: |
| """Analyze text and return statistics. |
| |
| Args: |
| text: The input text to analyze |
| |
| Returns: |
| JSON string with analysis results |
| """ |
| words = text.split() |
| chars = len(text) |
| chars_no_spaces = len(text.replace(" ", "")) |
| sentences = text.count(".") + text.count("!") + text.count("?") |
| |
| avg_word_length = round(chars_no_spaces / len(words), 2) if words else 0 |
| avg_sentence_length = round(len(words) / max(sentences, 1), 2) |
| |
| return json.dumps({ |
| "total_characters": chars, |
| "characters_without_spaces": chars_no_spaces, |
| "total_words": len(words), |
| "total_sentences": max(sentences, 1), |
| "average_word_length": avg_word_length, |
| "average_sentence_length": avg_sentence_length, |
| "unique_words": len(set(word.lower() for word in words)) |
| }) |
|
|
| @mcp.tool() |
| def extract_keywords(text: str, count: int = 5) -> str: |
| """Extract keywords (most common words) from text. |
| |
| Args: |
| text: The input text |
| count: Number of keywords to return (default 5) |
| |
| Returns: |
| JSON string with keywords and frequencies |
| """ |
| |
| stopwords = { |
| "the", "a", "an", "and", "or", "but", "in", "on", "at", "to", "for", |
| "of", "with", "is", "are", "was", "were", "be", "been", "by", "from" |
| } |
| |
| words = text.lower().split() |
| filtered = [w.strip(".,!?;:") for w in words if w.lower() not in stopwords] |
| |
| from collections import Counter |
| word_freq = Counter(filtered) |
| top_words = word_freq.most_common(count) |
| |
| return json.dumps({ |
| "keywords": [{"word": w, "frequency": f} for w, f in top_words] |
| }) |
|
|
| @mcp.tool() |
| def check_reading_level(text: str) -> str: |
| """Estimate reading difficulty level. |
| |
| Args: |
| text: The input text |
| |
| Returns: |
| JSON string with reading level estimate |
| """ |
| sentences = max(text.count(".") + text.count("!") + text.count("?"), 1) |
| words = len(text.split()) |
| syllables = text.count("a") + text.count("e") + text.count("i") + text.count("o") + text.count("u") |
| |
| if words == 0: |
| return json.dumps({"error": "No text to analyze"}) |
| |
| |
| grade = (0.39 * (words / sentences)) + (11.8 * (syllables / words)) - 15.59 |
| grade = max(0, round(grade, 1)) |
| |
| if grade < 6: |
| level = "Elementary School" |
| elif grade < 9: |
| level = "Middle School" |
| elif grade < 13: |
| level = "High School" |
| else: |
| level = "College/Academic" |
| |
| return json.dumps({ |
| "grade_level": grade, |
| "reading_level": level |
| }) |
|
|
| @mcp.tool() |
| def reverse_text(text: str) -> str: |
| """Reverse a string. |
| |
| Args: |
| text: The input text |
| |
| Returns: |
| The reversed text |
| """ |
| return text[::-1] |
|
|
| if __name__ == "__main__": |
| mcp.run() |