我有两个分支。提交a是一个的头,而另一个有b, c, d, e和f在a的顶部。我想移动c, d, e和f到第一个分支,而不提交b。使用樱桃采摘很容易:签出第一个分支樱桃采摘一个接一个c到f,并重新建立第二个分支到第一个。但是有没有办法在一个命令中选择所有的c-f ?
下面是场景的可视化描述(感谢JJD):
我有两个分支。提交a是一个的头,而另一个有b, c, d, e和f在a的顶部。我想移动c, d, e和f到第一个分支,而不提交b。使用樱桃采摘很容易:签出第一个分支樱桃采摘一个接一个c到f,并重新建立第二个分支到第一个。但是有没有办法在一个命令中选择所有的c-f ?
下面是场景的可视化描述(感谢JJD):
当前回答
另一个值得一提的变体是,如果你想要一个分支的最后n次提交,~语法可以很有用:
git cherry-pick some-branch~4..some-branch
在这种情况下,上面的命令将从一个名为some-branch的分支中选择最后4次提交(尽管您也可以使用提交散列来代替分支名称)
其他回答
除了提交之外,还可以通过管道从stdin输入sha列表。
git rev-list --reverse ..main -- path/ | git cherry-pick --stdin
Rev-list基本上是git-log的管道命令(“丑陋”但快速的表亲) 注意——反向是需要的。
您可以通过这种方式执行更高级的操作,而不仅仅是提交范围。
运用J. B. Rainsberger和sschaef的评论来具体回答这个问题…在这个例子中使用樱桃选择范围:
git checkout a
git cherry-pick b..f
or
git checkout a
git cherry-pick c^..f
git format-patch --full-index --binary --stdout range... | git am -3
我需要樱桃选择从一个分支到另一个优先级的提交,但这里的提交很难理解,希望下面的帮助与一个简单的:
步骤如下:
从“dev”分支获取1个带名字的提交(“移除姓氏字段”) 在"hotfix1"分支中提交
1。从“dev”分支获取提交细节
// Go to "dev" branch
git checkout dev
// Get the commit id (1e2e3e4e1 here)
git log --oneline
> ...
> ...
> 1e2e3e4e1 Remove Last Name field
> ...
> ...
2。推送提交到“hotfix1”分支
// Go to "hotfix1" branch
git checkout hotfix1
// Get the commit (1e2e3e4e1) from "dev" branch to "hotfix1" branch
git cherry-pick 1e2e3e4e1
// verify changes are correct
gitk
// push to "hotfix1" branch
git push
如果要一次做多个,只需要在上面修改一个,按顺序给出所有的提交id:
git cherry-pick 1e2e3e4e1 1e2e3e4e2 1e2e3e4e3
这里有一个脚本,允许你在一行中选择多个提交,只需告诉脚本哪个源和目标分支的樱桃选择和提交的数量:
https://gist.github.com/nickboldt/99ac1dc4eb4c9ff003a1effef2eb2d81
从你的分支中选择master(使用当前分支作为源):
./gcpl.sh -m
从6.19中挑选最新的5个提交。X科要掌握:
./gcpl.sh -c 5 -s 6.19.x -t master