Skip to main content

A Python package for technical analysis of financial markets

Project description

技术指标分析工具

该工具提供mcp服务器用于分析ETF和股票的技术指标。它使用akshare库获取历史数据,并计算RSI、布林带和移动平均线等技术指标。该工具支持ETF和股票历史数据分析。

API文档

mcp服务器提供的接口:

analyze_etf_technical

@mcp.tool()
def analyze_etf_technical(etf_code='510300', with_market_style=False):
    """
    ETF技术指标分析工具
    :param etf_code: ETF代码 (例如'510300')
    :param with_market_style: 是否包含市场风格分类 (True/False)
    :param base_date: 基准日期,格式为YYYYMMDD (可选)
    :return: 包含技术指标的Markdown表格(最后5条记录)
    """

新增字段说明:

参数:

  • etf_code: ETF代码,默认为'510300'(沪深300ETF)

返回值:

  • 包含以下技术指标的Markdown表格:
    • 价格数据
    • RSI指标
    • 布林带
    • 移动平均线
    • atr: 平均真实波幅(10日),衡量价格波动性的指标,数值越大表示波动越大
    • mkt_style: 市场风格分类结果

示例:

result = analyze_etf_technical('510300')
print(result)

analyze_stock_hist_technical

@mcp.tool()
def analyze_stock_hist_technical(stock_code='000001'):
    """
    股票历史数据技术指标分析工具
    :param stock_code: 股票代码 (例如'000001')
    :param base_date: 基准日期,格式为YYYYMMDD (可选)
    :return: 包含技术指标的Markdown表格(最后5条记录)
    """

参数:

  • stock_code: 股票代码,默认为'000001'(平安银行)

返回值:

  • 包含以下技术指标的Markdown表格:
    • 价格数据
    • RSI指标
    • 布林带
    • 移动平均线
    • atr: 平均真实波幅(10日),衡量价格波动性的指标,数值越大表示波动越大
    • mkt_style: 市场风格分类结果

示例:

result = analyze_stock_hist_technical('000001')
print(result)

get_stock_news

@mcp.tool()
def get_stock_news(news_count=3, publish_before=None):
    """
    以时间线方式获取股票市场最新事件,包括政策、行业动态和市场行情
    :param news_count: 返回新闻数量 (默认3条)
    :param publish_before: 发布日期上限 (格式YYYY-MM-DD)
    :return: 新闻列表 (JSON格式)
    """

参数:

  • news_count: 返回新闻数量,默认为3条
  • publish_before: 发布日期上限,格式为YYYY-MM-DD

返回值:

  • 新闻列表 (JSON格式)

示例:

result = get_stock_news(news_count=5)
print(result)

screen_etf_anomaly_in_tech

@mcp.tool()
def screen_etf_anomaly_in_tech(etf_codes="513050", base_date=None, lookback_days=60, top_k=10):
    """
    筛选ETF异动行情,基于技术指标分析找出近期表现异常的ETF
    :param etf_codes: 要筛选的ETF代码列表,默认为"513050",多个代码用逗号分隔
    :param base_date: 基准日期(格式YYYYMMDD),默认为当前日期
    :param lookback_days: 回溯天数,用于计算技术指标(默认60天)
    :param top_k: 返回排名前几的ETF(默认10个)
    :return: 包含异动ETF信息的Markdown表格,包括ETF代码、名称、异常指标和得分
    """

参数:

  • etf_codes: ETF代码列表,默认为"513050"
  • base_date: 基准日期,格式为YYYYMMDD
  • lookback_days: 回溯天数,默认为60天
  • top_k: 返回排名前几的ETF,默认为10个

返回值:

  • 包含异动ETF信息的Markdown表格

示例:

result = screen_etf_anomaly_in_tech(etf_codes="513050,510300")
print(result)

安装与配置

安装

pip install technical-analysis-mcp

配置

  1. 确保已安装Python 3.8+版本
  2. 需要配置akshare数据源(可选)
  3. 运行MCP服务器:
technical-analysis-mcp

市场风格分类示例

# 获取带市场风格分类的ETF技术指标
result = analyze_etf_technical('510300', with_market_style=True)
print(result)

# 获取带市场风格分类的股票技术指标
result = analyze_stock_hist_technical('000001', with_market_style=True)
print(result)

MCP配置示例

{
  "mcpServers": {
    "technical-analysis-mcp": {
      "command": "uvx",
      "args": ["technical-analysis-mcp"]
    }
  }
}

Restful API

使用uvicorn启动FastAPI应用:

uvicorn technical_analysis.http:app --reload --port 8000

应用启动后,可以通过以下地址访问API文档: http://localhost:8000/docs

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

technical_analysis_mcp-0.5.7.tar.gz (25.9 kB view details)

Uploaded Source

Built Distribution

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

technical_analysis_mcp-0.5.7-py3-none-any.whl (30.9 kB view details)

Uploaded Python 3

File details

Details for the file technical_analysis_mcp-0.5.7.tar.gz.

File metadata

File hashes

Hashes for technical_analysis_mcp-0.5.7.tar.gz
Algorithm Hash digest
SHA256 696c8d3edfcde3e53417b9d477992b698a74977747b7b579e39e8921803cc8ac
MD5 a9b967682c8e9a457e0e2ca138da6040
BLAKE2b-256 5a20b71b73f61179d6d86e90c6e765fbe88e4febd9bc2c5146ab8cba08065ce1

See more details on using hashes here.

File details

Details for the file technical_analysis_mcp-0.5.7-py3-none-any.whl.

File metadata

File hashes

Hashes for technical_analysis_mcp-0.5.7-py3-none-any.whl
Algorithm Hash digest
SHA256 371797f5db9581fd0333ff8e74205e04ec9bee8a86f66dc437446ce6416e4303
MD5 0c52dc9be6beceecabfc0a105b24053c
BLAKE2b-256 d37d00d986d76c8ce1315c73c1862c12e8efb33f9271442dfa67cefac539ccdc

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