Git 现场

2020-12-23  本文已影响0人  想溜了的蜗牛
  1. 场景:stash pop 后,发现不应该pop,
    解决方法: git reset --hard HEAD

refer: discard-git-stash-pop

  1. 场景:将之前上传到gitlab中的文件加到 .gitignore文件中;如将.env.production 等 env 忽略掉,不要上传到库中
    解决方法: 需要先将文件使用 git rm 删除一下,所以需要先备份一下,或者删除后从库中以前的版本再copy到本地
git rm env.local --cached

ignore文件就不写了,refer: stackoverflow

  1. 清除目录
    场景:项目被重写,目录变动非常。从新版本切回旧版查看代码时,会将旧版的目录下载,再切回新版后,旧的目录依然还在。怎么清除旧的文件或目录呢?
    方法: 使用 git clean
git clean -n  // 演习,告诉你会清哪些文件,不会真正删除
git clean -f  //删除当前目录下所有没有track过的文件. 他不会删除.gitignore文件里面指定的文件夹和文件, 不管这些文件有没有被track过
git clean -f <path>  // 删除指定路径下的没有被track过的文件
git clean -df  // 删除当前目录下没有被track过的文件和文件夹

参考 git clean的用法

  1. 文件(夹)名称大小写
    这个在 mac 下使用 git mv myfile MyFile 类似 git rm xxfile
    但在 windows 下经常用有权限的问题,所以 windows 下麻烦些. 套路;
    a. 把A目录备份为B
    b. 删除A目录
    c. git add 那些deleted的文件
    d. 将目录B改名为你要的名字X
    e. git add X
    执行完上边再 git status 能看到 renamed xxx -> XXX
    文件同目录操作一样。

  2. error: fatal: Unable to create /.git/index.lock': File exists
    处理: rm -f ./.git/index.lock
    refer: link

  3. 临时保存后切到别的分支 refer,
    保存:git stash save “修改的信息"
    取出:

git stash list
git stash apply stash@{0}
  1. git add 后,有某个文件不需要提交
    git reset head

  2. 本地有修改,但现在要拉个全新的分支, 另外本地修改没啥影响,想全部丢弃
    git reset --hard or git checkout .

  3. 修改本地与远程分支名
    refer: How To Rename a Local and Remote Git Branch

# 1. Start by switching to the local branch which you want to rename:
git checkout <old_name>
# 2. Rename the local branch by typing:
git branch -m <new_name>
# 3. Push the <new_name> local branch and reset the upstream branch:
git push origin -u <new_name>
# 4. Delete the <old_name> remote branch:
git push origin --delete <old_name>
  1. stash clear 后的恢复
    refer stackoverflow
# 1. 用下面命令先找出 commit 列表
git fsck --unreachable | grep commit | cut -d ' ' -f3 | xargs git log --merges --no-walk --grep=WIP
# 2. 找到你的 commit id 后,如下操作(可能你是没有commit, 但stash会当成一个commit)
git stash apply <commit id>
  1. stash 没有 track 的文件
    refer: stackoverflow
git stash  -u
  1. 找出当前代码中所有修改的文件
git diff-tree -r --no-commit-id --name-only --diff-filter=ACMRT $commit_id
# 需要将修改后的文件打包用这个
git diff-tree -r --no-commit-id --name-only --diff-filter=ACMRT $commit_id | tar -czf file.tgz -T -

refer: stackoverflow
执行后展示如下:

image.png
  1. cherry-pick
    帮同事合代码时,发现他的分支少了之前的 develop 分支的一个 commit,此时可以将这个 commit 使用 cherry-pick 再合到他的分支就可以了
# 1. 使用git log 找到刚漏了的commit
git log 
# 2. 
git cherry-pick <commitHash>
# 3. 如果有冲突,解决冲突后执行
git add conflict_file
git cherry-pick --continue
git commit -c db617f5
git push origin dev-branch-name

refer: git-cherry-pick, Using_Git_Cherry_Pick#Resolve_conflicts

上一篇 下一篇

猜你喜欢

热点阅读