Git branch -a显示远程分支和本地分支。
Git branch -r显示远程分支。
是否有一种方法只列出本地分支?
Git branch -a显示远程分支和本地分支。
Git branch -r显示远程分支。
是否有一种方法只列出本地分支?
如果前导星号是一个问题,我将按如下方式管道git分支
git branch | awk -F ' +' '! /\(no branch\)/ {print $2}'
这也消除了“(无分支)”线,显示当你有分离的头。
下面是如何列出没有相同名称的远程分支的本地分支:
git branch | sed 's|* | |' | sort > local
git branch -r | sed 's|origin/||' | sort > remote
comm -23 local remote
为了补充gertvdijk的回答,我添加了一些截图,以防它能快速帮助到某人。
在我的Git Bash shell中,如果我运行以下命令:
git branch
这个命令(不带参数)显示我的所有本地分支。当前签出的分支以不同的颜色(绿色)显示,并带有一个星号(*)前缀,这非常直观。
当你尝试使用-a(代表all)参数查看所有分支,包括远程分支时:
git branch -a
然后还没有签出的远程分支也会以不同的(红色)颜色显示:
关于如何删除本地分支的帖子有一个很好的答案。在其中,下面的代码构建了一个命令来列出本地分支:
git branch -vv | cut -c 3- | awk '$3 !~/\[/ { print $1 }'
关于这个命令是如何导出的,答案有一个很好的解释,所以我建议你去阅读那篇文章。
Use:
git show-ref --heads
gertvdijk的回答是最简洁和优雅的,但这可能有助于理解refs/heads/*等同于局部分支的想法。
大多数情况下,refs/heads/master ref是一个位于. Git /refs/heads/master的文件,其中包含一个Git提交散列,指向代表本地主分支当前状态的Git对象,因此. Git /refs/heads/*下的每个文件都代表一个本地分支。
PowerShell用户可以使用它的Compare-Object cmdlet来做这样的事情:
function match-branch {
$localBranches = ((git branch -l) -replace "\*", "") -replace " ", ""
$remoteBranches = (((git branch -r) -replace "\*", "") -replace " ", "") -replace "origin/", ""
Compare-Object -ReferenceObject $localBranches -DifferenceObject $remoteBranches -IncludeEqual
| Select-Object @{Label = "branch"; Expression = { $_.InputObject } },
@{Label = ”both”; Expression = { $_.SideIndicator -eq "==" } },
@{Label = ”remoteOnly”; Expression = { $_.SideIndicator -eq "=>" } },
@{Label = ”localOnly”; Expression = { $_.SideIndicator -eq "<=" } }
}
示例输出
branch both remoteOnly localOnly
------ ---- ---------- ---------
master True False False
HEAD->master False True False
renamed False True False
使用git分支的——格式,你可以显示本地分支及其配置的远程和合并配置(在repo的.git/config文件中可以找到)。
git branch --format='%(HEAD) %(refname:short) -> %(upstream:short)'
参见git分支使用的git for-each-ref的格式文档
您可以在~/.gitconfig中添加它作为别名
[alias]
[...]
brem = branch --format='%(HEAD) %(refname:short) -> %(upstream:short)'
[...]
例子
在当地有5个分支机构 有2个远程位置:原点和上游 名为upstream的本地分支被配置为推/拉到上游的主分支 命名为test的本地分支没有推送到任何地方,也没有配置远程/合并
> git branch --format='%(HEAD) %(refname:short) -> %(upstream:short)'
* main -> origin/main
release/v0.01 -> origin/release/v0.01
release/v0.02 -> origin/release/v0.02
test ->
upstream -> upstream/main