2

这是我的输入文件,比如 modified.txt

------------------------------------------------------------------------
r4544 | n479826 | 2012-08-28 07:12:33 -0400 (Tue, 28 Aug 2012) | 1 line
Changed paths:
   M /branches/8.6.0/conf/src/main/config/RTSConfig.xml

CET-402: some text comment
------------------------------------------------------------------------
r4550 | n479826 | 2012-09-04 05:51:29 -0400 (Tue, 04 Sep 2012) | 1 line
Changed paths:
   M /branches/8.6.0/conf/src/main/config/RTSConfig.xml
   M /branches/8.6.0/conf/src/main/config/base.cfg
   M /branches/8.6.0/conf/src/main/config/prod.cfg
   M /branches/8.6.0/conf/src/main/config/qa.cfg
   M /branches/8.6.0/conf/src/main/config/uat.cfg

CET-438: some text comment

我的输出应该是这样的:

r4544 | n479826 | 2012-08-28 07:12:33 | /branches/8.6.0/conf/src/main/config/RTSConfig.xml
r4550 | n479826 | 2012-09-04 05:51:29 | /branches/8.6.0/conf/src/main/config/RTSConfig.xml
r4550 | n479826 | 2012-09-04 05:51:29 | /branches/8.6.0/conf/src/main/config/base.cfg
r4550 | n479826 | 2012-09-04 05:51:29 | /branches/8.6.0/conf/src/main/config/prod.cfg
r4550 | n479826 | 2012-09-04 05:51:29 | /branches/8.6.0/conf/src/main/config/qa.cfg
r4550 | n479826 | 2012-09-04 05:51:29 | /branches/8.6.0/conf/src/main/config/uat.cfg

输入文件是一个示例 svn-log 文件。我想用它们各自的凭据过滤所有修改过的(M)文件。有人可以帮助提供一些示例代码。提前致谢。

4

1 回答 1

3
awk -F"|" '/^r/{a=$1;b=$2;c=substr($3,0,20)}/^   M/{gsub(/   M /," ");print a"|"b"|"c"|"$0}' your_file

测试:

> awk -F"|" '/^r/{a=$1;b=$2;c=substr($3,0,20)}/^   M/{gsub(/   M /," ");print a"|"b"|"c"|"$0}' temp
r4544 | n479826 | 2012-08-28 07:12:33| /branches/8.6.0/conf/src/main/config/RTSConfig.xml
r4550 | n479826 | 2012-09-04 05:51:29| /branches/8.6.0/conf/src/main/config/RTSConfig.xml
r4550 | n479826 | 2012-09-04 05:51:29| /branches/8.6.0/conf/src/main/config/base.cfg
r4550 | n479826 | 2012-09-04 05:51:29| /branches/8.6.0/conf/src/main/config/prod.cfg
r4550 | n479826 | 2012-09-04 05:51:29| /branches/8.6.0/conf/src/main/config/qa.cfg
r4550 | n479826 | 2012-09-04 05:51:29| /branches/8.6.0/conf/src/main/config/uat.cfg

解释:

/^r/{a=$1;b=$2;c=substr($3,0,20)}

只有当行以字母 r 开头时,上面的代码块才会执行。块内部说将第一个字段存储在 a 中,第二个字段存储在 b 中,输入的第三个字段是:

2012-08-28 07:12:33 -0400 (Tue, 28 Aug 2012)

但我只需要带有时间戳的日期,其余的对我来说已经过时了。它始终是 20 个字符。所以我从第三个字段中取出一个子字符串并将其存储在 c 中。

我的主要兴趣是以 /^ M/ 开头的行,我必须显示上一行中以 r 开头的信息,并且确保在我们想要的行之前有一行以 r 开头,其中包含所有信息我必须在前面加上以 M 开头的行。

因此,每次以 M 开头的行都会添加存储在 ab 和 c 中的值。

M/{gsub(/ M /," ");print a"|"b"|"c"|"$0}

gsub 部分将从当前行中删除带有空格的“ M ”部分。print 部分只是在当前行前面加上 ab 和 c 的值 | 作为分隔符。

于 2013-01-15T11:50:14.883 回答