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

相关推荐
2401_8260976218 小时前
同步&异步日志系统-日志落地模块的实现
c++·git·vim
半旧夜夏18 小时前
阿里云IOT消息处理
java·ide·git·物联网·spring·阿里云
我们的五年20 小时前
【Git版本控制器】第三弹——版本回退,撤销修改,删除文件
大数据·linux·git
一名嵌入式糕手20 小时前
Git从基础到进阶
git
不cong明的亚子21 小时前
github用户名密码登陆失效了
git·github
QC七哥21 小时前
git开发流程以及github社区企业版
git·github
邂逅you1 天前
GitHub基本操作及Git简单命令
git·github
EngZegNgi1 天前
git 提示 fatal: The remote end hung up unexpectedly
git
ricky_fan1 天前
本地部署MindSearch(开源 AI 搜索引擎框架),然后上传到 hugging face的Spaces——L2G6
人工智能·git·python
misty youth1 天前
github与git bash绑定问题
git·github·bash