Git Revert 特定文件/路径的方法

git revert 命令本身不支持直接指定文件或路径,但有几种方法可以实现你的需求。


方法1:使用 git checkout(推荐 - 最简单)

恢复单个文件到指定提交

复制代码
# 将某个文件恢复到 master 分支的状态
git checkout master -- src/main/java/PriceFilter.java

# 将某个文件恢复到指定提交的状态
git checkout 8b68b626 -- src/main/java/PriceFilter.java

# 恢复后需要提交
git add src/main/java/PriceFilter.java
git commit -m "revert: 恢复 PriceFilter.java 到 master 状态"

# 恢复整个目录到 master 状态
git checkout master -- src/main/java/

# 恢复多个文件
git checkout master -- file1.java file2.java

# 恢复当前目录下所有 .java 文件
git checkout master -- *.java

方法2:使用 git restore(Git 2.23+推荐)

复制代码
# 将文件恢复到 master 分支状态
git restore --source=master src/main/java/PriceFilter.java

# 将文件恢复到指定提交状态
git restore --source=8b68b626 src/main/java/PriceFilter.java

# 恢复整个目录
git restore --source=master src/main/java/

# 提交更改
git add .
git commit -m "revert: 恢复指定文件到 master 状态"


# 恢复到工作区(默认)
git restore --source=master --worktree src/main/java/PriceFilter.java

# 恢复到暂存区
git restore --source=master --staged src/main/java/PriceFilter.java

# 同时恢复到工作区和暂存区
git restore --source=master --worktree --staged src/main/java/PriceFilter.java

方法3:手动 Revert + 选择性恢复

复制代码
# 1. 先正常 revert 整个提交
git revert cc53969d --no-commit

# 2. 查看被 revert 的文件
git status

# 3. 恢复不需要 revert 的文件
git checkout HEAD -- 不需要revert的文件.java

# 4. 只保留需要 revert 的文件更改
git add 需要revert的文件.java

# 5. 提交
git commit -m "revert: 仅恢复部分文件到指定状态"

方法4:使用 IDEA 图形化操作

单个文件恢复

  1. 在项目树中右键点击目标文件
  2. GitShow History
  3. 在历史记录中找到目标提交(如 master 的最新提交)
  4. 右键点击该提交 → Get Revision
  5. 确认恢复该文件到选定版本

目录恢复

  1. 右键点击目标目录
  2. GitRepositoryReset
  3. 选择目标提交
  4. 选择 Mixed 模式
  5. 在弹出的文件列表中只选择需要的文件
  6. 点击 Reset
相关推荐
小前端学徒5 小时前
重新修改未提交到远程分支不是最后一次commit的内容
git
执键行天涯5 小时前
idea中已经被git缓存追踪的文件,如何让git重新忽略
git·缓存·intellij-idea
hkhkhkhkh1235 小时前
Git push 失败(remote unpack failed: Missing tree)解决方案
linux·git
拾贰_C6 小时前
【anaconda】anaconda安装配置,git安装配置以及pytorch安装
人工智能·pytorch·git
Just_Paranoid9 小时前
【Gerrit Patch】批量下载 Gerrit 提交的 Patch
git·gerrit·shell·patch
T - mars1 天前
Pycharm中使用git
ide·git·pycharm
jason_yang1 天前
Workspace搭建Vue3+组件分离的Monorepo项目
git·npm·前端工程化
鸽鸽程序猿1 天前
【Git】Git 简介及基本操作
git
ziyue75752 天前
idea终端添加git-bash,支持linux的shell语法
linux·git·bash·idea·软件
风也温柔☆2 天前
idea 拉取分支git pull报错 The branch to pull from should be selected
git·intellij-idea·debug·git pull