go-musicfox | 另一个Spotify版 Spotifox
go-musicfox 是用 Go 写的又一款网易云音乐命令行客户端,支持各种音质级别、UnblockNeteaseMusic、Last.fm、MPRIS 和 macOS 交互响应(睡眠暂停、蓝牙耳机连接断开响应和菜单栏控制等)等功能特性。
UI 基于 charmbracelet/bubbletea 进行了部分定制
(The icon is based on kitty-icon)
[!IMPORTANT] 需要满足以下条件:
- go-musicfox >= v3.7.7
- 下载和安装 LyricsX 的 go-musicfox 的 fork 版本
- 在 LyricsX 设置中,打开
使用系统正在播放的应用
$ brew install anhoder/go-musicfox/go-musicfox // 指定 --head 使用master代码编译安装如果你之前安装过 musicfox,需要使用下列命令重新链接:
$ brew unlink musicfox && brew link --overwrite go-musicfox在 Release 下载 macOS 的可执行文件。
从 AUR 安装
$ paru -S go-musicfox # 下载源代码编译安装
$ paru -S go-musicfox-bin # 下载安装预编译好的二进制# pacman -S go-musicfox从 星火商店 安装。
$ sudo aptss install go-musicfox //二进制包部署,同步较慢
$ sudo aptss install go-musicfox-git //从源码编译,请保持网络通畅从 gentoo-zh Overlay 安装
$ eselect repository enable gentoo-zh
$ emerge --sync
$ emerge -a media-sound/go-musicfox1. flake support
下面是一个在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-musicfox2. 配置 configuration.nix 或使用 Home Manager(推荐)
# configuration.nix
environment.systemPackages = [
pkgs.go-musicfox
];
# home manager
home.packages = [
pkgs.go-musicfox
];从 void-packages-zh 安装。
$ 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 开发套件
请根据你的发行版,选择适合你的安装命令:
- APT (Debian, Ubuntu)
$ 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- pacman (Arch)
$ sudo pacman -S flac- DNF (Fedora)
$ 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设置为false -
本应用不对 macOS 原生终端和 Windows 的命令提示符(CMD)做兼容处理(#99)
Linux 用户推荐使用 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 支持
这些是程序核心框架提供的基础操作,其快捷键通常无法通过配置文件修改。
| 配置标识符 | 操作说明 | 默认按键 |
|---|---|---|
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 |
addSelectedSongToUserPlaylist |
将选中歌曲加入歌单 | Tab |
removeSelectedSongFromUserPlaylist |
将选中歌曲从歌单中删除 | Shift+Tab |
downloadSelectedSong |
下载选中歌曲 | D |
downloadSelectedSongLrc |
下载选中歌曲的歌词 | |
openAlbumOfSelectedSong |
选中歌曲的所属专辑 | A |
openArtistOfSelectedSong |
选中歌曲的所属歌手 | S |
openSelectedItemInWeb |
网页打开选中歌曲/专辑... | O |
collectSelectedPlaylist |
收藏选中歌单 | ;, :, :, ; |
discollectSelectedPlaylist |
取消收藏选中歌单 | ', " |
simiSongsOfSelectedSong |
与选中歌曲相似的歌曲 | F |
actionOfSelected |
对于选中项或当前播放的操作 | m |
actionOfPlayingSong |
对于当前播放的操作 | M |
toggleSortOrder |
切换排序顺序(电台/播客列表) | ` |
注意:
- 非字符快捷键大小写不敏感,如
shift+tab等同Shift+Tab,但a与A不同 - 多次绑定同一个键的行为是未定义的,以程序最后读取的为准
- 不可自定义操作 不可自定义且其使用的键也不可用于自定义
- 与歌曲、歌单等存在关联的操作现已默认添加至
actionOfSelected及actionOfPlayingSong
示例配置:
[keybindings]
# 取消所有默认键绑定(须自定义键以确保正常使用)
useDefaultKeyBindings = false
# 应用内快捷键
[keybindings.app]
# 将“下一首”改为 Alt+N
next = "alt+n"
# 为“帮助”额外添加 Ctrl+H
help = ["?","ctrl+h"]
# 取消“心动模式”的默认 P 键
intelligence = ""
# 将“显示当前播放列表”改为 Ctrl+P
curPlaylist = "ctrl+p"默认不设置任何全局快捷键,如果需要请在配置文件中的global_hotkey下进行配置,例如:
[keybindings.global]
# 格式:键=功能
"ctrl+shift+space" = "toggle"因为Linux下开启全局快捷键需要安装比较多的依赖,可能你并不需要这个功能,所以Releases中的Linux二进制文件是不支持全局快捷键的
如果需要开启,请安装依赖后手动进行编译:
BUILD_TAGS=enable_global_hotkey make build
- 确保
enableMouseEvent设置为true - 详见 鼠标支持说明
分享文本的内容是完全可定制的,它由一套模板系统驱动(使用 text/template ,支持条件判断等高级用法)。
| 字段分组 | 包含字段 |
|---|---|
Song |
SongId: 歌曲ID SongName: 歌曲名称 SongArtists: 歌曲的艺术家名 SongUrl: 歌曲链接 |
Album |
AlbumId: 专辑ID AlbumName: 专辑名称 AlbumUrl: 专辑链接 AlbumArtists: 专辑的艺术家名 |
Artist |
ArtistId: 歌手ID ArtistName: 歌手姓名 ArtistUrl: 歌手链接 |
Playlist |
PlaylistId: 歌单ID PlaylistName: 歌单名称 PlaylistUrl: 歌单链接 |
User |
UserID: 用户ID UserName: 用户昵称 UserUrl: 用户链接 |
DjRadio |
DjRadioId: 播客电台ID DjRadioName: 播客电台名称 DjRadioUrl: 播客电台链接 |
Episode |
EpisodeId: 播客节目ID EpisodeName: 播客节目名称 EpisodeUrl: 播客节目链接 |
注意:
- 对于
episode(播客节目)类型,由于其本质也是一首“歌曲”,因此它同时拥有Episode、Song和Album的所有字段。其中EpisodeName和SongName的值是相同的。
不同类型的分享项目,其可用的信息字段也不同。例如,分享一首“歌曲”时,您可以同时获取到“歌曲信息”和它所属的“专辑信息”;而分享一个“歌手”时,则只有“歌手信息”。 不支持自定义模板名
| 模板名称 | 说明 | 可用字段分组 |
|---|---|---|
song |
用于分享一首单曲。 | Song, Album |
album |
用于分享一张专辑。 | Album |
artist |
用于分享一位歌手。 | Artist |
playlist |
用于分享一个歌单。 | Playlist, User |
user |
用于分享一位用户。 | User |
djRadio |
用于分享一个播客电台。 | DjRadio, User |
episode |
用于分享播客中的一期节目。 | Episode, DjRadio, User, Song, Album |
[share]
song = "分享{{if .SongArtists}}{{.SongArtists}}的{{end}}单曲《{{.SongName}}》: {{.SongUrl}} (来自@网易云音乐)"
配置文件路径为用户配置目录下的 config.toml 文件,详细可参见配置示例。
用户配置目录路径:
macOS:$HOME/Library/Application Support/go-musicfox
Linux:$XDG_CONFIG_HOME/go-musicfox 或 $HOME/.config/go-musicfox
Windows:%AppData%\go-musicfox
你可以通过设置 MUSICFOX_ROOT 环境变量来自定义用户配置的存储位置
旧版本的 go-musicfox 的默认用户配置目录为 $HOME/.go-musicfox(*nix)或 %USERPROFILE%\.go-musicfox(Windows),升级到新版本时将自动迁移到上述的新路径
注意:配置文件格式已从 INI 迁移至 TOML。如果您的旧版本配置文件仍为 INI 格式,请运行 musicfox migrate 命令进行迁移,或运行 musicfox help migrate 查看更多选项。
config.toml 文件,详细可参见配置示例。用户配置目录路径:
macOS:$HOME/Library/Application Support/go-musicfox
Linux:$XDG_CONFIG_HOME/go-musicfox 或 $HOME/.config/go-musicfox
Windows:%AppData%\go-musicfox
你可以通过设置 MUSICFOX_ROOT 环境变量来自定义用户配置的存储位置
旧版本的 go-musicfox 的默认用户配置目录为 $HOME/.go-musicfox(*nix)或 %USERPROFILE%\.go-musicfox(Windows),升级到新版本时将自动迁移到上述的新路径
注意:配置文件格式已从 INI 迁移至 TOML。如果您的旧版本配置文件仍为 INI 格式,请运行 musicfox migrate 命令进行迁移,或运行 musicfox help migrate 查看更多选项。
See CHANGELOG.md
- go-musicfox/bubbletea:基于 bubbletea 进行部分定制
- go-musicfox/netease-music:fork 自 NeteaseCloudMusicApiWithGo ,在原项目的基础上去除 API 功能,只保留 service 和 util 作为一个独立的包,方便在其他 Go 项目中调用
感谢以下项目及其贡献者们(但不限于):