0. 前情提要
想修改一下我的某个文件/文件夹名字,发现一改,怎么这个文件绿色的 √ 就没了???改回来之后,√ 又回来了!!!特么的,咋回事呢?
别急, Git 追踪文件是根据文件名来的,把文件名改了,它就不知道那该死的文件去哪了,它就以为你删掉了!!!所以你在本地直接改名一个文件之后,git status 发现的就是 deleted 和 untracked。但这不是我的本意啊!!!
所以想要修改文件名,我们就需要用到 git mv 命令了。
1. git mv 详解重命名
重命名文件或文件夹可以使用 git mv 命令。参数详解:
-v:显示信息。
-f:强制重命名或移动,会覆盖目标文件。
-k:跳过对重命名或移动出错的文件。出错的时候发生在源文件不存在,或者没有追踪的源文件,或者目标文件已经存在,但没有加-f进行覆盖。
-n:只显示信息,但不会进行实际重命名或移动操作。
注意文件状态:
- 只能修改已经追踪的文件和文件夹
- 修改之后,相当于执行了
add,直接commit就可以提交。
1.1 重命名文件
-f 指强制重命名或移动,注意:若目标已经存在,则会覆盖目标文件。
$ git mv -v oldfile newfile
# $ git mv -f oldfile newfile
# 已经追踪,无需进行 add -u
$ git status
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)
renamed: oldfile -> newfile
# 重命名之后正常 commit push 就可以了
$ git commit -m "rename oldfile to newfile"
$ git push
1.2 重命名文件夹
/ 不会产生影响。若 newfolder 文件夹原本已经存在,则会将 oldfolder 移入 newfolder。
$ git mv -v oldfolder newfolder
# $ git mv -v oldfolder/ newfolder/
# 已经追踪,无需进行 add -u
$ git status
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)
renamed: oldfolder/... -> newfolder/...
# 重命名之后正常 commit push 就可以了
$ git commit -m "rename oldfolder to newfolder"
$ git push
本文详细解析了在Git版本控制系统中如何正确地重命名文件或文件夹,避免因直接修改文件名导致的追踪丢失问题。通过使用git mv命令,可以确保文件历史记录的连续性,同时介绍了命令的参数选项及其应用场景。

203

被折叠的 条评论
为什么被折叠?



