从 svn 日志中提取已删除文件的名称



我需要提取在提交之间删除的文件名。我有这个命令:

svn log -r 1:30 -v | grep ' D ' | awk -F ' ' '{print $2}'

对于此命令

svn log -r 28:30 -v 

输出为:

r28 | admin | 2017-08-08 10:02:03 +0000 (Út, 08 srp 2017) | 1 line
Changed paths:
D /smartsvn-linux-9_2_1.tar.gz
Remove test file 1
------------------------------------------------------------------------
r29 | admin | 2017-08-08 10:02:21 +0000 (Út, 08 srp 2017) | 1 line
Changed paths:
D /smartsvn-linux-9_2_1 (copy).tar.gz
Remove test file 2
------------------------------------------------------------------------
r30 | admin | 2017-08-08 10:02:52 +0000 (Út, 08 srp 2017) | 1 line
Changed paths:
D /testfile.txt
Remove testing file 3

对于此命令:

svn log -r 28:30 -v | grep ' D ' 

输出为:

D /smartsvn-linux-9_2_1.tar.gz
D /smartsvn-linux-9_2_1 (copy).tar.gz
D /testfile.txt

从该输出中,我想得到一个没有字母 D 的输出:

/smartsvn-linux-9_2_1.tar.gz
/smartsvn-linux-9_2_1 (copy).tar.gz
/testfile.txt

它几乎可以正常工作,但如果文件名包含空格,则不起作用。我明白为什么会发生这种情况,但我不知道,我该如何解决它。还是有更好的方法,我该怎么做?

编辑:同时我解决了我的问题,但我确定这是垃圾。它有效,但我相信它存在更好的方式。我只会使用 grep 或 egrep,但我无法确定 grep 或 egrep 是否支持组。

svn log -r 1:30 -v | grep ' D ' | egrep '/([a-zA-Z_.0-9-() -]+)$' -o

无需grep,就可以用awk来实现grep能做的事情。 使用/ D/筛选包含D的行

您可以使用awk打印从 6 开始$0子字符串(这是您想要的模式的起点(

$ svn log -r 28:30 -v | awk '/ D/{print substr($0,6)}'

或者您可以使用sub(/[^/]*/过滤掉non-/

$ svn log -r 28:30 -v | awk '/ D/{sub(/[^/]*/,"",$0);print $0}'

最新更新