Añadir docstrings y anotaciones de tipo
Es hora de hacer que tu herramienta convert_currency() sea más fácil de usar para los LLM mediante docstrings y anotaciones de tipo. Sin esto, el LLM puede no ser capaz de elegir eficazmente qué herramienta llamar, o puede pasar valores a los argumentos de forma incorrecta, lo que en ambos casos provoca un rendimiento poco fiable de la aplicación.
Ya se ha instanciado un servidor MCP usando FastMCP y se ha asignado a mcp.
Este ejercicio forma parte del curso
Introducción a Model Context Protocol (MCP)
Instrucciones del ejercicio
- Añade los tipos adecuados a los argumentos de la función y al objeto de retorno.
- Completa el docstring para hacer coincidir los tres argumentos de la función con sus definiciones.
ejercicio interactivo práctico
Prueba este ejercicio completando este código de ejemplo.
# Adding typing to the function arguments and return object
@mcp.tool()
def convert_currency(amount: ____, from_currency: ____, to_currency: ____) -> ____:
# Complete the docstring with the function arguments
"""
Convert an amount from one currency to another using current exchange rates.
Args:
____: The amount to convert
____: Source currency code (e.g., 'USD', 'EUR', 'GBP')
____: Target currency code (e.g., 'USD', 'EUR', 'GBP')
Returns:
A string with the conversion result and exchange rate
"""
url = f"https://api.frankfurter.dev/v1/latest?base={from_currency}&symbols={to_currency}"
response = requests.get(url)
data = response.json()
rate = data['rates'].get(to_currency)
if rate is None:
return f"Could not find exchange rate for {from_currency} to {to_currency}"
converted_amount = amount * rate
return f"{amount} {from_currency} = {converted_amount:.2f} {to_currency} (Rate: {rate})"
print(convert_currency(amount=100, from_currency="EUR", to_currency="USD"))