go-musicfox 是用 Go 写的又一款网易云音乐命令行客户端,支持各种音质级别、UnblockNeteaseMusic、Last.fm、MPRIS 和 macOS 交互响应(睡眠暂停、蓝牙耳机连接断开响应和菜单栏控制等)等功能特性,以及 DLNA 投送。
UI 基于 charmbracelet/bubbletea 进行了部分定制

(The icon is based on kitty-icon)









[!IMPORTANT] 需要满足以下条件: 1. go-musicfox >= v3.7.7 2. 下载和安装 LyricsX 的 go-musicfox 的 fork 版本 3. 在 LyricsX 设置中,打开
使用系统正在播放的应用
$ brew install anhoder/go-musicfox/go-musicfox // 指定 --head 使用master代码编译安装
如果你之前安装过 musicfox,需要使用下列命令重新链接:
$ brew unlink musicfox && brew link --overwrite go-musicfox
在 Release 下载 macOS 的可执行文件。
$ paru -S go-musicfox # 下载源代码编译安装
$ paru -S go-musicfox-bin # 下载安装预编译好的二进制
archlinuxcn 安装# pacman -S go-musicfox
$ sudo dnf copr enable poesty/go-musicfox
$ sudo dnf install go-musicfox
$ sudo aptss install go-musicfox //二进制包部署,同步较慢
$ sudo aptss install go-musicfox-git //从源码编译,请保持网络通畅
$ eselect repository enable gentoo-zh
$ emerge --sync
$ emerge -a media-sound/go-musicfox
下面是一个在nixos配置中使用它的例子
{
description = "My configuration";
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
go-musicfox.url = "github:go-musicfox/go-musicfox";
};
outputs = { nixpkgs, go-musicfox, ... }:
{
nixosConfigurations = {
hostname = nixpkgs.lib.nixosSystem
{
system = "x86_64-linux";
modules = [
{
nixpkgs.overlays = [ go-musicfox.overlays.default ];
environment.systemPackages = with pkgs;[
go-musicfox
];
}
];
};
};
};
}
临时运行:
$ nix run github:go-musicfox/go-musicfox
# configuration.nix
environment.systemPackages = [
pkgs.go-musicfox
];
# home manager
home.packages = [
pkgs.go-musicfox
];
安装到本地 profile:
$ nix-env -iA nixos.go-musicfox
临时安装:
$ nix-shell -p go-musicfox
从 void-packages-zh 安装。
$ apt install go-musicfox
如果遇到卡顿,请切换到mpd播放引擎
$ brew install anhoder/go-musicfox/go-musicfox // 指定 --head 使用master代码编译安装
如果你之前安装过 musicfox,需要使用下列命令重新链接:
$ brew unlink musicfox && brew link --overwrite go-musicfox
在 Release 下载 Linux 的可执行文件。
scoop bucket add go-musicfox https://github.com/go-musicfox/go-musicfox.git
scoop install go-musicfox
在 Release 下载 Windows 的可执行文件。
注:需要 Go v1.22 及以上版本
前往 下载 Go 页面选择适合你的 Go 安装包体。
Linux 需要 libFLAC-dev 开发套件
请根据你的发行版,选择适合你的安装命令:
$ sudo apt install software-properties-common build-essential
$ sudo add-apt-repository ppa:longsleep/golang-backports //ubuntu默认go语言版本为1.18,需要更新到1.21
$ sudo apt install libflac-dev libasound2-dev golang-go
$ sudo pacman -S flac
$ sudo dnf install flac-devel
其他发行版请根据相应文档寻找 libflac-dev 开发套件安装说明。
$ git clone https://github.com/go-musicfox/go-musicfox
$ go mod download
$ make # 编译到 bin 目录下
$ make install # 安装到 $GOPATH/bin下
$ musicfox
doubleColumn 设为 false,否则双列显示排版可能会混乱enableMouseEvent 设置为 falseLinux 用户推荐使用 Kitty
Windows 用户推荐使用 Windows Terminal,使用体验更佳
libFLAC.so.8:
./musicfox: error while loading shared libraries: libFLAC.so.8: cannot open shared object file: No such file or directory
例如 Ubuntu 23.10 及它的衍生版系列,libFLAC.so.12 已经将 libFLAC.so.8 替换。遇到这种问题,你可以:
* 找到已安装的新版 libFLAC.so,将其软链为libFLAC.so.8: ln -s /xxx/libFLAC.so /xxx/libFLAC.so.8 (推荐)
* 自行安装 libflac8 (不推荐)
* 参照手动编译一节自行编译。
这里之所以使用 FLAC8,主要是为了兼容大部分系统,因为FLAC是向前兼容的(也就是说
≥ 8的FLAC都可以使用) - wsl 环境下使用 beep 须安装libasound2-plugins,见 issues - XDG 支持
自 #453 起,提供了完整的 XDG 支持,部分文件路径变更,见 XDG 支持说明 - 配置文件格式 自 #484 起,配置文件格式已由 INI 更换为 TOML
DLNA 引擎允许你将音乐投送到兼容 DLNA 的设备(如智能电视、音响、游戏机等)。
gupnp-tools:brew install gupnp-tools(macOS)或 sudo apt install gupnp-tools(Linux)运行 gupnp-universal-cp,扫描并复制设备的描述 URL(形如 http://192.168.1.100:49152/description.xml)
配置
在 config.toml 中设置:
```toml
[player]
engine = "dlna"
[player.dlna] deviceUrl = "http://你的设备IP:端口/description.xml" localIP = "本机局域网IP" # 例如 192.168.1.50 ```
这些是程序核心框架提供的基础操作,其快捷键通常无法通过配置文件修改。
| 配置标识符 | 操作说明 | 默认按键 |
|---|---|---|
rerender |
重新渲染UI | r, R |
moveLeft |
左 | h, H, Left |
moveRight |
右 | l, L, Right |
moveUp |
上 | k, K, Up |
moveDown |
下 | j, J, Down |
moveToTop |
上移到顶部 | g |
moveToBottom |
下移到底部 | G |
enter |
进入 | n, N, Enter |
goBack |
返回上一级 | b, B, Esc |
search |
搜索当前列表 | /, /, 、 |
quit |
退出 | q, Q |
你可以在配置文件的 [keybindings] 部分修改这些操作的快捷键。
| 配置标识符 | 操作说明 | 默认按键 |
|---|---|---|
help |
帮助信息 | ?, ? |
pageUp |
上一页 | Ctrl+u, PgUp |
pageDown |
下一页 | Ctrl+d, PgDown |
playortoggle |
播放/暂停 | Space, , |
toggle |
切换播放状态 | (无) |
previous |
上一首 | [, 【 |
next |
下一首 | ], 】 |
backwardOneSec |
快退1秒 | x |
backwardFiveSec |
快退5秒 | X |
forwardFiveSec |
快进5秒 | v |
forwardTenSec |
快进10秒 | V |
downVolume |
减小音量 | -, −, ー |
upVolume |
加大音量 | =, = |
switchPlayMode |
切换播放模式 | p |
intelligence |
心动模式 | P |
clearSongCache |
清除音乐缓存 | u, U |
logout |
注销并退出 | w, W |
curPlaylist |
显示当前播放列表 | c, C |
appendSongsToNext |
添加为下一曲播放 | e |
appendSongsAfterCurPlaylist |
添加到播放列表末尾 | E |
delSongFromCurPlaylist |
从播放列表删除选中歌曲 | \, 、 |
likePlayingSong |
喜欢播放中歌曲 | ,, , |
dislikePlayingSong |
取消喜欢播放中歌曲 | ., 。 |
trashPlayingSong |
标记播放中歌曲为不喜欢 | t |
addPlayingSongToUserPlaylist |
将播放中歌曲加入歌单 | ` |
removePlayingSongFromUserPlaylist |
将播放歌曲从歌单中删除 | ~, ~ |
downloadPlayingSong |
下载播放中歌曲 | d |
downloadPlayingSongLrc |
下载当前播放音乐歌词 | Ctrl+l |
openAlbumOfPlayingSong |
播放中歌曲的所属专辑 | a |
openArtistOfPlayingSong |
播放中歌曲的所属歌手 | s |
openPlayingSongInWeb |
网页打开播放中歌曲 | o |
simiSongsOfPlayingSong |
与播放中歌曲相似的歌曲 | f |
likeSelectedSong |
喜欢选中歌曲 | <, 〈, <, 《, « |
dislikeSelectedSong |
取消喜欢选中歌曲 | >, 〉, >, 》, » |
trashSelectedSong |
标记选中歌曲为不喜欢 | T |
$ claude mcp add go-musicfox \
-- python -m otcore.mcp_server <graph>