Git branch -a显示远程分支和本地分支。

Git branch -r显示远程分支。

是否有一种方法只列出本地分支?


只是简单的命令

git branch

只是git分支没有选项。

从手册中:

如果没有参数,则列出现有分支,当前分支将用星号突出显示。


如果前导星号是一个问题,我将按如下方式管道git分支

git branch | awk -F ' +' '! /\(no branch\)/ {print $2}'

这也消除了“(无分支)”线,显示当你有分离的头。


获取本地分支列表的另一种方法是:

git branch -a | grep -v 'remotes'

最直接的方法之一是

git for-each-ref --format='%(refname:short)' refs/heads/

这也适用于脚本。


下面是如何列出没有相同名称的远程分支的本地分支:

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 -a -所有分支。

git branch -r仅用于远程分支。

git branch -只支持本地分支。


关于如何删除本地分支的帖子有一个很好的答案。在其中,下面的代码构建了一个命令来列出本地分支:

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