如何同时获取暂存区和未暂存区的文件列表(包括新增和修改文件)?

作者站长头像
站长
· 阅读数 33

git 获取修改文件和新增文件列表(不包过删除文件)

git ls-files 命令

git ls-files --others --exclude-standard    // 获取新增文件列表
git ls-files --modified --exclude-standard  // 获取修改文件列表
git ls-files --deleted --exclude-standard   // 获取删除文件列表

没有添加到暂存区上面的命令是正常的,添加到暂存区获取不到对应的文件。

需要实现一下功能:1.获取修改文件列表(不包括删除文件);2.获取新增文件列表;3.文件是否在暂存空间,都能获取到文件列表(暂存空间文件和未暂存空间文件重复去重);

已暂存

git diff --name-only --cached                  // 获取暂存区所有文件
git diff --name-only --cached --diff-filter=A  // 获取新增文件
git diff --name-only --cached --diff-filter=D  // 获取删除文件
git diff --name-only --cached --diff-filter=M  // 获取修改文件
git diff --name-only --cached --diff-filter=d  // 排除删除文件

--diff-filter 参数:A:新增文件D:已删除文件M:修改过文件小写字母取反;

未暂存

git ls-files --exclude-standard --others    // 新增
git ls-files --exclude-standard --modified  // 修改
git ls-files --exclude-standard --deleted   // 删除

git ls-files --exclude-standard --others --modified 获取未暂存区新增修改文件,但是包括了删除的文件。

取差集命令 comm

comm [-123][--help][--version][第1个文件][第2个文件]

参数:-1 不显示只在第1个文件里出现过的列-2 不显示只在第2个文件里出现过的列-3 不显示只在第1和第2个文件里出现过的列

comm -3 <(git ls-files --exclude-standard --deleted | sort) <(git ls-files --exclude-standard --others --modified | sort)

comm -3 <(git ls-files --exclude-standard --deleted | sort) <(git ls-files --exclude-standard --others --modified | sort) | sed -e 's/^[[:space:]]*//'

sed -e 's/^[[:space:]]*//' 清除输出的文件前面的空格

感谢大家的回答,问题解决。

回复
1个回答
avatar
test
2024-06-20

功能说明:1.获取修改文件列表(不包括删除文件);2.获取新增文件列表;3.文件是否在暂存空间,都能获取到文件列表(暂存空间文件和未暂存空间文件重复去重)。


1.获取未暂存文件列表(不包括删除文件):

comm -3 <(git ls-files --exclude-standard --deleted | sort) <(git ls-files --exclude-standard --others --modified | sort) | sed -e 's/^[[:space:]]*//'

2.获取暂存文件列表:

git diff --name-only --cached --diff-filter=d 

3.获取暂存空间和未暂存空间文件列表并过滤重复项:

comm -3 <(git diff --name-only --cached --diff-filter=d | sort) <(comm -3 <(git ls-files --exclude-standard --deleted | sort) <(git ls-files --exclude-standard --others --modified | sort) | sed -e 's/^[[:space:]]*//') | sed -e 's/^[[:space:]]*//'

相关资料说明:git ls-files 命令(获取未暂存文件列表):

git ls-files --exclude-standard --others    // 获取新增文件列表
git ls-files --exclude-standard --modified  // 获取修改文件列表
git ls-files --exclude-standard --deleted   // 获取删除文件列表

git diff 命令(获取暂存文件列表):

git diff --name-only --cached                  // 获取暂存区所有文件
git diff --name-only --cached --diff-filter=A  // 获取新增文件
git diff --name-only --cached --diff-filter=D  // 获取删除文件
git diff --name-only --cached --diff-filter=M  // 获取修改文件
git diff --name-only --cached --diff-filter=d  // 排除删除文件

--diff-filter 参数:A:新增文件D:已删除文件M:修改过文件小写字母取反;


comm 命令(取列表差集):

comm [-123][--help][--version][第1个文件][第2个文件]

参数:-1 不显示只在第1个文件里出现过的列-2 不显示只在第2个文件里出现过的列-3 不显示只在第1和第2个文件里出现过的列

sed -e 's/^[[:space:]]*//' 清除输出的文件前面的空格

感谢大家的帮助。

回复
likes
适合作为回答的
  • 经过验证的有效解决办法
  • 自己的经验指引,对解决问题有帮助
  • 遵循 Markdown 语法排版,代码语义正确
不该作为回答的
  • 询问内容细节或回复楼层
  • 与题目无关的内容
  • “赞”“顶”“同问”“看手册”“解决了没”等毫无意义的内容