当前位置: 首页 > java >正文

bilibili-mcp 使用示例

目录

    • 🚀 安装和设置
      • 1. 克隆项目
      • 2. 创建虚拟环境
      • 3. 安装依赖
    • 完整代码
    • 代码解释
      • 📦 导入模块
      • 🔧 初始化和配置
      • 🌐 网络请求函数
      • 🛠 主要工具函数
    • 🔍 调试和测试
    • 📝 注意事项
    • 💡 使用场景示例

🚀 安装和设置

1. 克隆项目

git clone https://github.com/xspadex/bilibili-mcp.git
cd bilibili-mcp

在这里插入图片描述

2. 创建虚拟环境

uv venv
source .venv/bin/activate  # Linux/Mac
# 或者在 Windows 上:
.venv\Scripts\activate

在这里插入图片描述

3. 安装依赖

uv pip install -e .

完整代码

bilibili_mcp.py

from typing import Any
import httpx
from mcp.server.fastmcp import FastMCP# Initialize FastMCP server for Bilibili popular list
mcp = FastMCP("blbl")# API endpoint for B 站热榜
BILIBILI_POPULAR_URL = "https://api.bilibili.com/x/web-interface/popular"
USER_AGENT = "blbl-mcp/1.0"headers = {"User-Agent": "qwq"
}async def make_request(url: str, top_k: int = 3) -> dict[str, Any] | None:async with httpx.AsyncClient(http2=False) as client:try:response = await client.get(url, headers=headers, params={"ps": top_k, "pn": 1})response.raise_for_status()return response.json()except Exception as e:print(e)return None@mcp.tool()
async def get_popular(top_k: int = 3) -> dict[str, Any] | str:"""Fetch the current Bilibili popular videos list.Returns the raw JSON from Bilibili’s popular interface,or an error message if the fetch fails."""top_k = min(top_k, 10)data = await make_request(BILIBILI_POPULAR_URL, top_k)if data is None:return "Unable to fetch Bilibili popular list."data_list = data['data']['list']result = []for item in data_list:title = item['title']link = item['short_link_v2']desc = item['desc']view = item['stat']['view']like = item['stat']['like']result.append({'title': title,'link': link,'desc': desc,'view': view,'like': like})if len(result) >= top_k:breakreturn resultif __name__ == "__main__":# Run the MCP server over stdiomcp.run(transport='stdio')

代码解释

📦 导入模块

from typing import Any
import httpx
from mcp.server.fastmcp import FastMCP
  • typing.Any:用于类型注解,表示任意类型
  • httpx:现代异步 HTTP 客户端库,用于发送网络请求
  • FastMCP:MCP(Model Context Protocol)的快速实现框架

🔧 初始化和配置

# Initialize FastMCP server for Bilibili popular list
mcp = FastMCP("blbl")# API endpoint for B 站热榜
BILIBILI_POPULAR_URL = "https://api.bilibili.com/x/web-interface/popular"
USER_AGENT = "blbl-mcp/1.0"headers = {"User-Agent": "qwq"
}
  • 创建名为 “blbl” 的 FastMCP 服务器实例
  • 定义 B 站热榜 API 的 URL 端点
  • 设置请求头,包含 User-Agent 信息(注意:代码中实际使用的是 “qwq”)

🌐 网络请求函数

async def make_request(url: str, top_k: int = 3) -> dict[str, Any] | None:async with httpx.AsyncClient(http2=False) as client:try:response = await client.get(url, headers=headers, params={"ps": top_k, "pn": 1})response.raise_for_status()return response.json()except Exception as e:print(e)return None

功能说明:

  • 异步函数,用于发送 HTTP GET 请求
  • 使用 httpx.AsyncClient 创建异步客户端(禁用 HTTP/2)
  • 请求参数:
    • ps:每页数量(page size)
    • pn:页码(page number),固定为 1
  • 错误处理:捕获异常并返回 None
  • 成功时返回 JSON 响应数据

🛠 主要工具函数

@mcp.tool()
async def get_popular(top_k: int = 3) -> dict[str, Any] | str:"""Fetch the current Bilibili popular videos list.Returns the raw JSON from Bilibili's popular interface,or an error message if the fetch fails."""top_k = min(top_k, 10)data = await make_request(BILIBILI_POPULAR_URL, top_k)if data is None:return "Unable to fetch Bilibili popular list."data_list = data['data']['list']result = []for item in data_list:title = item['title']link = item['short_link_v2']desc = item['desc']view = item['stat']['view']like = item['stat']['like']result.append({'title': title,'link': link,'desc': desc,'view': view,'like': like})if len(result) >= top_k:breakreturn result

功能详解:

  1. 装饰器 @mcp.tool():将函数注册为 MCP 工具,可被外部调用

  2. 参数限制top_k = min(top_k, 10) 确保最多返回 10 个视频

  3. 数据获取:调用 make_request 函数获取 B 站 API 数据

  4. 数据解析:从 API 响应中提取关键信息:

    • title:视频标题
    • short_link_v2:短链接
    • desc:视频描述
    • stat.view:播放量
    • stat.like:点赞数
  5. 结果格式化:返回结构化的字典列表

🔍 调试和测试

使用 MCP Inspector 可以方便地测试工具:

  1. 启动 Inspector:npx @modelcontextprotocol/inspector
  2. 在浏览器中打开 http://127.0.0.1:6277
  3. 连接到您的 bilibili-mcp 服务器
  4. 测试 get_popular 工具的各种参数
    在这里插入图片描述
    在这里插入图片描述

📝 注意事项

  • 确保 Python 版本 ≥ 3.12
  • 避免过于频繁地调用 B 站 API
  • 工具返回的数据基于 B 站公开接口
  • 默认最多返回 10 个视频信息

💡 使用场景示例

  1. 获取热门内容灵感

    请帮我获取当前B站热榜前5个视频,我想了解最近的热门话题
    
  2. 分析热门趋势

    获取B站热榜数据,分析一下当前最受欢迎的内容类型
    
  3. 内容创作参考

    查看B站热榜,帮我分析哪些类型的视频容易获得高播放量
    
http://www.xdnf.cn/news/13273.html

相关文章:

  • 7.6 Finetuning the LLM on instruction data
  • 论文分享 _ Ladder:一种基于收敛的结构化图区块链_2025-06-10
  • 实战案例-FPGA如何实现JESD204B可重复的延迟
  • 2005-2021年中国地下水位年鉴数据(EXCEL/PDF)包含:各省监测点、监测深度等
  • 【存储系统】
  • 理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端
  • 全新AI驱动Workspace Security 套件发布!Fortinet 电子邮件安全产品矩阵升级
  • PHP 多种内置的验证规则和函数
  • 在Jenkins上配置邮箱通知
  • 2025-03-15-位运算
  • 第一部分 -- ①语法分析的概要
  • Yolov5.6增加注意力机制+ByterTrack:目标检测与跟踪
  • Linux(Centos 7.6)命令详解:find
  • 揭秘OpenJDK 17字节码解释引擎:模板解释器深度解析
  • C++ 中的尾调用优化TCO:原理、实战与汇编分析
  • 鹰盾加密器如何对视频进行分析?
  • 工模、老化apk中Framewok定制开发的场景
  • Docker 操作容器[SpringBoot之Docker实战系列] - 第538篇
  • 常用数组方法、字符串方法、数组 ↔ 字符串 的转换、TS类型提示 (大全)
  • 二.Gitee分支管理
  • 端口转发和SSH隧道的含义详解及使用方法
  • 用哈希表封装myunordered_map和 myunordered_set(沉淀中)
  • 【Linux基础知识系列】第十七篇-使用Docker进行容器管理
  • 华为OD机试_2025 B卷_相对开音节(Python,100分)(附详细解题思路)
  • 大语言模型原理与书生大模型提示词工程实践-学习笔记
  • 目标跟踪_学习
  • GNSS位移监测站的作用
  • 龙蜥开发者说:我的龙蜥开源之旅 | 第 32 期
  • 寄存器被改写问题总结
  • 有符号变量与无符号变量的区别和联系