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
相关推荐
nyf_unknown2 小时前
(vue)将文件夹打成tar包, Git Bash(推荐)具体使用
vue.js·git·bash
星哥说事19 小时前
如何将堡塔云WAF迁移到新的服务器
服务器·git·github
阿政一号1 天前
Git版本控制器
git
妮妮喔妮1 天前
SSH协议的GIT转换
运维·git·ssh
今禾1 天前
Git 日常使用与面试考点详解:从入门到精通
前端·git·面试
Data_Adventure2 天前
能连上 GitHub(SSH 验证成功),却 push 失败?常见原因与逐步解决方案
前端·git·github
间彧2 天前
如何解决Git客户端下载缓慢问题
git
Tearstornbyrain2 天前
在Ubuntu24.04中使用ssh连接本地git仓库到github远程仓库
linux·git·ubuntu·ssh·github
四七伵2 天前
一次 Git Rebase 事故,让我彻底明白 Rebase 和 Merge 的区别
git·后端