我需要提取在提交之间删除的文件名。我有这个命令:
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}'