Git常用命令

Git 详细命令列表

1. 项目初始化和克隆

  • git init:在当前目录初始化一个新的 Git 仓库。

  • git clone <repository> [<directory>]: 克隆一个远程仓库到本地,可选指定本地目录。

2. 文件操作

  • git add <file>: 将文件添加到暂存区。

  • git add .: 将所有修改过的文件添加到暂存区。

  • git status: 查看仓库状态,包括修改过的文件、暂存区文件等。

  • git diff: 查看工作区和暂存区之间的差异。

  • git diff --cached: 查看暂存区和上次提交之间的差异。

  • git diff HEAD: 查看工作区和上次提交之间的差异。

  • git rm <file>: 从工作区和暂存区删除文件。

  • git mv <old-file> <new-file>: 重命名文件。

3. 提交操作

  • git commit -m "<message>": 将暂存区的文件提交到本地仓库,并附带提交信息。

  • git commit -a -m "<message>": 将所有已跟踪文件的修改提交到本地仓库,并附带提交信息。

  • git commit --amend: 修改上次提交,包括提交信息和文件内容。

4. 分支操作

  • git branch: 列出所有分支,当前分支前面会有 * 号。

  • git branch <branch-name>: 创建一个新的分支。

  • git checkout <branch-name>: 切换到指定分支。

  • git checkout -b <branch-name>: 创建并切换到一个新的分支。

  • git merge <branch-name>: 将指定分支合并到当前分支。

  • git branch -d <branch-name>: 删除本地分支。

  • git branch -D <branch-name>: 强制删除本地分支,即使未合并。

5. 远程仓库操作

  • git remote: 列出所有远程仓库。

  • git remote -v: 列出所有远程仓库及其 URL。

  • git remote add <name> <url>: 添加一个新的远程仓库。

  • git remote remove <name>: 删除一个远程仓库。

  • git remote rename <old-name> <new-name>: 重命名一个远程仓库。

  • git fetch <remote>: 从远程仓库获取最新代码,但不合并到本地分支。

  • git pull <remote> <branch>: 从远程仓库获取最新代码并合并到当前分支。

    • --rebase: 使用 rebase 方式合并,而不是 merge。
  • git push <remote> <branch>: 将本地分支推送到远程仓库。

    • -u: 设置本地分支与远程分支的关联,下次推送可以直接使用 git push。

    • -f: 强制推送,即使远程分支有更新。

    • --tags: 推送所有标签。

6. 标签操作

  • git tag: 列出所有标签。

  • git tag <tag-name>: 创建一个新的标签。

  • git tag -a <tag-name> -m "<message>": 创建一个新的标签并附带信息。

  • git tag -d <tag-name>: 删除本地标签。

  • git push <remote> <tag-name>: 将标签推送到远程仓库。

  • git push <remote> --tags: 将所有标签推送到远程仓库。

7. 日志操作

  • git log: 查看提交历史记录。

    • -p: 显示每次提交的差异。

    • --oneline: 以一行显示每次提交的信息。

    • --graph: 以图形化方式显示提交历史。

    • --author=<author>: 筛选特定作者的提交。

    • --since=<date>: 筛选特定日期之后的提交。

    • --until=<date>: 筛选特定日期之前的提交。

8. 其他常用命令

  • git stash: 将当前工作区的修改保存到 stash 中。

  • git stash pop: 从 stash 中恢复最近保存的修改。

  • git stash list: 列出所有 stash。

  • git stash clear: 清空 stash。

  • git cherry-pick <commit-hash>: 将指定的提交应用到当前分支。

  • git rebase <branch-name>: 将当前分支的提交 rebase 到指定分支上。

  • git reset <commit-hash>: 将当前分支回滚到指定的提交。

    • --hard: 彻底回滚,工作区和暂存区也会被重置。

    • --soft: 只回滚提交记录,工作区和暂存区不受影响。

    • --mixed: 回滚提交记录和暂存区,工作区不受影响。

  • git revert <commit-hash>: 通过创建一个新的提交来撤销指定的提交。

相关推荐
yylの博客2 小时前
Windows通过git-bash安装zsh
windows·git·bash·zsh
丁总学Java2 小时前
(Z Shell)zsh: no matches found: ? 使用单引号包裹
git·zsh
萌狼蓝天3 小时前
【NAS】绿联NAS+极狐Gitlab+1Panel
git
deja vu水中芭蕾8 小时前
git push origin HEAD:refs/for/分支名
git
海岛日记12 小时前
git常用操作
git
喝鸡汤12 小时前
一起学Git【番外篇:如何在Git中新建文件】
git
“αβ”12 小时前
Windows下使用git配置gitee远程仓库
git
谢家小布柔17 小时前
Git图形界面以及idea中集合Git使用
java·git
winner888118 小时前
git merge 冲突 解决 show case
java·git·git merge·git冲突
玩电脑的辣条哥1 天前
怎么给git动图扣除背景?
git·抠图