这是一个针对YouTube的模型上下文协议(MCP)服务器实现,使AI语言模型能够通过标准化接口与YouTube内容进行交互。
要自动通过Smithery为Claude Desktop安装YouTube MCP服务器:
npx -y @smithery/cli install @ZubeidHendricks/youtube --client claude
npm install zubeid-youtube-mcp-server
设置以下环境变量:
YOUTUBE_API_KEY
:您的YouTube Data API密钥YOUTUBE_TRANSCRIPT_LANG
:字幕的默认语言(可选,默认为英文)将以下内容添加到您的MCP客户端配置中(例如Claude Desktop):
{
"mcpServers": {
"youtube": {
"command": "npx",
"args": ["-y", "zubeid-youtube-mcp-server"],
"env": {
"YOUTUBE_API_KEY": "<您的API密钥>"
}
}
}
}

要实现一键安装,请点击下面的安装按钮之一:
如果您更喜欢手动安装,首先检查本节顶部的安装按钮。否则,请按照以下步骤操作:
将以下JSON块添加到VS Code的用户设置(JSON)文件中。您可以通过按Ctrl + Shift + P
并输入Preferences: Open User Settings (JSON)
来完成此操作。
{
"mcp": {
"inputs": [
{
"type": "promptString",
"id": "apiKey",
"description": "YouTube API Key",
"password": true
}
],
"servers": {
"youtube": {
"command": "npx",
"args": ["-y", "zubeid-youtube-mcp-server"],
"env": {
"YOUTUBE_API_KEY": "${input:apiKey}"
}
}
}
}
}

或者,您可以将其添加到工作区中的.vscode/mcp.json
文件中:
{
"inputs": [
{
"type": "promptString",
"id": "apiKey",
"description": "YouTube API Key",
"password": true
}
],
"servers": {
"youtube": {
"command": "npx",
"args": ["-y", "zubeid-youtube-mcp-server"],
"env": {
"YOUTUBE_API_KEY": "${input:apiKey}"
}
}
}
}

// 获取视频详情
const video = await youtube.videos.getVideo({
videoId: "视频ID"
});
// 获取视频字幕
const transcript = await youtube.transcripts.getTranscript({
videoId: "视频ID",
language: "en"
});
// 搜索视频
const searchResults = await youtube.videos.searchVideos({
query: "搜索词",
maxResults: 10
});

// 获取频道详情
const channel = await youtube.channels.getChannel({
channelId: "频道ID"
});
// 列出频道视频
const videos = await youtube.channels.listVideos({
channelId: "频道ID",
maxResults: 50
});

// 获取播放列表项目
const playlistItems = await youtube.playlists.getPlaylistItems({
playlistId: "播放列表ID",
maxResults: 50
});
// 获取播放列表详情
const playlist = await youtube.playlists.getPlaylist({
playlistId: "播放列表ID"
});

# 安装依赖
npm install
# 运行测试
npm test
# 构建
npm run build
# 代码检查
npm run lint

有关为该仓库做贡献的信息,请参阅CONTRIBUTING.md。
本项目采用MIT许可证 - 详情请参见LICENSE文件。