git 写了挺多内容了突然发现自己居然是在 master 分支上写的 希望带着已经写的内容去开一个新分支 怎么做? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
git
Pro Git
Atlassian Git Tutorial
Pro Git 简体中文翻译
GitX
Newyorkcity
V2EX    git

git 写了挺多内容了突然发现自己居然是在 master 分支上写的 希望带着已经写的内容去开一个新分支 怎么做?

  •  
  •   Newyorkcity 2020-07-09 20:58:09 +08:00 via Android 4289 次点击
    这是一个创建于 1924 天前的主题,其中的信息可能已经有所发展或是发生改变。
    谢谢!
    19 条回复    2020-07-11 02:29:36 +08:00
    Trim21
        1
    Trim21  
       2020-07-09 21:00:31 +08:00   2
    git checkout -b new-branch
    THaGKI9
        2
    THaGKI9  
       2020-07-09 21:01:30 +08:00 via iPhone   1
    你已经 commit 了吗?

    已经 commit 的话可以开新的 branch,然后 cherry pick

    没 commit 的话直接开新的 branch 就好了,active change 会带过去的
    across
        3
    across  
       2020-07-09 21:02:56 +08:00 via iPhone   1
    退回到 master 之前的 A 点,建新分支,然后把之前的内容 Squash 过来....
    gwy15
        4
    gwy15  
       2020-07-09 21:03:38 +08:00   1
    msg7086
        5
    msg7086  
       2020-07-09 21:23:23 +08:00 via Android
    给当前提交打上新的分支标记,然后把 master 回退回去。
    如果还没提交的话可以直接新建并切换分支。
    THaGKI9
        6
    THaGKI9  
       2020-07-09 21:26:45 +08:00 via iPhone
    @msg7086 号思路!
    yongzhong
        7
    yongzhong  
       2020-07-09 21:27:59 +08:00   4
    git stash push
    git checkout -b new_branch
    git stash pop
    zhuweiyou
        8
    zhuweiyou  
       2020-07-10 01:31:01 +08:00
    直接开,会带过去的。
    KentY
        9
    KentY  
       2020-07-10 07:13:28 +08:00
    看起来你是没 push, 但是 committed already.
    如果没 committed, 很容易 co -b 就可以了
    已经 committed 了有个省心的法:
    1) checkout -b newbranch
    2)然后在你本地把 master branch 删了
    3)pull
    完事
    dubenshu
        10
    dubenshu  
       2020-07-10 08:23:10 +08:00 via iPhone
    没 commit
    $ git stash
    $ git stash branch <new-branch>
    已经 commit
    $ git checkout -b <new-branch>
    nutting
        11
    nutting  
       2020-07-10 08:26:19 +08:00
    有没有人说说已经提交的话,ui 界面上是怎么操作
    ericgui
        12
    ericgui  
       2020-07-10 08:32:08 +08:00
    git branch -m "new-branch-name"

    git fetch origin master


    basically, you'll need to reset the master branch.
    hantsy
        13
    hantsy  
       2020-07-10 09:05:49 +08:00
    如果 Push 了的话,可以尝试(记不得了, 以前这种事,我也出现过。):

    1, 直接在 Master 建立分支。

    2, 然后 Master 上 Reset --Hard 上个点,commit, push 。一般 --hard 还是慎用。

    不过这种应该要避免,首先从切换到一个好的 Shell 开始(各种 OhMyXXX 系列),一般图形工具都是会标注当前分支。
    hantsy
        14
    hantsy  
       2020-07-10 09:06:35 +08:00
    @ericgui 重命名真没想到
    as94boy
        15
    as94boy  
       2020-07-10 09:33:01 +08:00
    @KentY 这种简单粗暴的方法,一开始真的还没想到。但是很赞。
    yinft
        16
    yinft  
       2020-07-10 13:27:50 +08:00
    直接开就能带过去哦
    yinft
        17
    yinft  
       2020-07-10 13:29:55 +08:00
    git checkout -b
    julyclyde
        18
    julyclyde  
       2020-07-10 14:29:32 +08:00
    1 把自己这个“本地 master”push 到远程的新分支
    2 然后把自己本地 master“倒回去”
    EscYezi
        19
    EscYezi  
       2020-07-11 02:29:36 +08:00 via iPhone
    @nutting #11 idea 的话可以 undo commit - create new branch and check out - commit&push
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     1411 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 25ms UTC 16:47 PVG 00:47 LAX 09:47 JFK 12:47
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86