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>: 通过创建一个新的提交来撤销指定的提交。

相关推荐
贩卖纯净水.2 小时前
白月光git
git·github
爱吃瓜的猹z6 小时前
git reset 几点疑问
git·源代码管理
悟空201612 小时前
001、Git开发流程规范
git
Li小李同学Li12 小时前
git学习【持续更新中。。。】
git·学习·elasticsearch
晨春计14 小时前
【git】
android·linux·git
神技圈子15 小时前
【git系列】git中的那些迷惑的术语以及概念详解
git
benben04416 小时前
Photoshop使用方法大全
git
ou.cs16 小时前
git 删除远程分支的几种写法
git
atlanteep16 小时前
Linux·权限与工具-git与gdb
linux·git