NetEase-MusicBox

June 3, 2026 · View on GitHub

Software License PyPI - Version PyPI - Python Version

高品质网易云音乐命令行客户端,基于 Python 编写。

感谢为 MusicBox 的开发付出过努力的每一个人

网易云音乐 API 能力由 NeteaseCloudMusicApiEnhanced/api-enhanced 提供支持。

Demo

NetEase-MusicBox-GIF

功能特性

  • 支持多档音质播放:MP3(极高/较高/标准)及无损、高清臻音、超清母带等 FLAC,安装 mpv 后自动切换
  • 支持歌曲、艺术家、专辑、本地列表模糊搜索
  • 支持排行榜、新碟上架、精选歌单、主播电台、我的歌单、我的云盘、私人 FM 和每日推荐
  • 支持本地收藏、歌曲评论、专辑跳转、随心打碟和定时退出
  • 支持播放进度、播放模式、当前/历史播放列表和桌面歌词显示
  • 支持 Vim 风格快捷键、数字快捷键和自定义全局快捷键

安装

推荐用 uvpipx 安装为全局命令 musicbox;参与开发见下文「本地开发」。

环境要求

  • Python 3.10 及以上
  • mpg123(MP3)、mpv(可选,FLAC / Hi-Res)

安装系统依赖

macOS:

brew install mpg123 mpv uv

Ubuntu/Debian:

sudo apt-get install mpg123 mpv

CentOS/Red Hat:

sudo yum install -y python3-devel mpg123 mpv

安装 MusicBox

PyPI(可能落后于源码):

uv tool install netease-musicbox
# 或 pipx install NetEase-MusicBox

源码(全局命令;改代码后需重装,开发期可用 -e):

git clone https://github.com/darknessomi/musicbox.git
cd musicbox
uv tool install .      # 或 pipx install .
uv tool install -e .   # 可编辑安装,源码改动即时生效

本地开发(不装全局命令):

git clone https://github.com/darknessomi/musicbox.git
cd musicbox
uv sync
uv run musicbox

可选依赖

  • aria2:缓存歌曲
  • libnotify-bin:Linux 消息提示
  • qtpy python-dbus dbus qt:桌面歌词。根据系统 Qt 版本,可能还需要安装 pyqt4pysidepyside2

树莓派 / 老旧设备

Ubuntu 22.04 / 64 位树莓派系统自带 Python 3.10,可用 pipx 直接安装。低性能设备建议先只装 MP3 播放必需依赖,避免一次性拉取 mpv 的大量图形/视频依赖:

sudo apt-get update
sudo apt-get install -y --no-install-recommends pipx mpg123
pipx ensurepath
pipx install NetEase-MusicBox
musicbox

注意:项目要求 Python 3.10 及以上;旧版 Raspberry Pi OS / Debian 如果仍是 Python 3.9,不能直接安装当前版本。

已验证系统

  • Ubuntu 24.04 LTS x64
  • macOS 26.5
  • Raspberry Pi 4 / Ubuntu 22.04 arm64(Docker 镜像:balenalib/raspberrypi4-64-ubuntu:jammy

使用

启动 MusicBox:

musicbox

进入需要登录的功能时,终端会显示二维码。登录方式仅支持扫码登录,已不再支持账号密码登录。

  1. 用网易云音乐手机 App 扫描二维码,并在手机上确认。
  2. 登录成功后 Cookie 写入 ~/.local/share/netease-musicbox/cookie.txt(未设置 XDG_DATA_HOME 时为 ~/.netease-musicbox/cookie.txt)。

终端以字符块渲染二维码,窗口建议 ≥25 行、等宽字体。无法扫描时,可复制提示中的 https://music.163.com/login?codekey=... 链接另行生成二维码。

快捷键

num + 的快捷键支持数字修饰,先输入数字,再输入被修饰的按键。

按键功能说明
jDown下移
kUp上移
num + jQuick Jump快速向后跳转 n 首
num + kQuick Up快速向前跳转 n 首
hBack后退
lForward前进
uPrev Page上一页
dNext Page下一页
fSearch当前列表模糊搜索
[Prev Song上一曲
]Next Song下一曲
num + [Quick Prev Song快速前 n 首
num + ]Quick Next Song快速后 n 首
num + Shift + gIndex for Song跳到第 n 首
=Volume +音量增加
-Volume -音量减少
SpacePlay/Pause播放/暂停
?Shuffle手气不错
mMenu主菜单
pPresent/History当前/历史播放列表
iMusic Info当前音乐信息
Shift + pPlaying Mode播放模式切换
aAdd添加曲目到打碟
Shift + aEnter Album进入专辑
gTo the First跳至首项
Shift + gTo the End跳至尾项
zDJ List打碟列表
sStar添加到收藏
cCollection收藏列表
rRemove删除当前条目
Shift + jMove Down向下移动当前项目
Shift + kMove Up向上移动当前项目
Shift + cCache缓存歌曲到本地
,Like喜爱
.Trash FM删除 FM
/Next FM下一 FM
qQuit退出
tTiming Exit定时退出
wQuit & Clear退出并清除用户信息

配置

配置文件位于 ~/.netease-musicbox/config.json,可配置缓存、快捷键、消息提示和桌面歌词。

无损播放相关配置:

  • music_quality:音质等级,可填数字或 level 名称。

    配置值说明
    jymaster超清母带,192kHz/24bit
    4 / hires高清臻音,96kHz/24bit
    3 / lossless无损,最高 48kHz/16bit
    0 / exhigh极高,最高 320kbps
    1 / higher较高,192kbps
    2 / standard标准,128kbps
  • player_backend:默认 mpg123;设为 mpv 则全程用 mpv,否则仅 FLAC 自动切到 mpv

  • mpv_parameters: 传给 mpv 的额外参数列表。

由于歌曲 API 只接受中国大陆地区访问,非中国大陆地区用户需要自行设置代理。可用 polipo 将 socks5 代理转换成 http 代理:

export http_proxy=http://IP:PORT
export https_proxy=http://IP:PORT
curl -L ip.cn

确认显示 IP 属于中国大陆地区即可。

排错

  • 某些歌曲不能播放且总时长为 00:01 时,通常是版权问题。
  • 特定终端不能播放时,先检查同一终端下 mpg123 能否正常使用,再检查其他终端下 musicbox 能否正常使用。报告 issue 时请附上这些检查结果和终端报错。
  • 可通过 tail -f ~/.local/share/netease-musicbox/musicbox.log 查看日志。

更新日志

详见 CHANGELOG.md

License

MIT