shell-script – 从40行文件中提取每2行并创建一个新文件
作者:互联网
我有一个40行的文件,如下所示:
0001.Group admin_group
0001.Users adam, sam, paul, david, jennifer, harry
0002.Group Dev_group
0002.Users mike, pauli, gary, sherry
0003.Group Sec_group
0003.Users david, diana, mike, paul, harry
0004.Group Main_group
0004.Users wilson, robert, samule
我需要使用前缀提取Group和Users,并创建一个与该组同名的新文件.
应该是这样的:
>输出文件名:admin_group,内容:
0001.Group admin_group
0001.Users adam, sam, paul, david, jennifer, harry
>输出文件名:Dev_group,内容:
0002.Group Dev_group
0002.Users mike, pauli, gary, sherry
最后,我需要有20个新的文本文件.我尝试使用sed和awk创建两个单独的文件并失败.我怎样才能在Bash或Python中获得这个?
解决方法:
不像awk版本那么聪明,但这里有另一种选择.
497844.txt是你的文件名.我曾用过问题编号
for f in `cut -f1 -d. 497844.txt | sort | uniq`
do
group=`grep $f.Group 497844.txt`
fn=`echo $group| cut -f2 -d" "`
grep ^$f 497844.txt > $fn
done
说明.
对于每个唯一的组编号,我们得到文件名,该文件名是包含Group的行的值.
然后,我们使用此组编号提取每一行,并将输出重定向到上面派生的文件中.
希望这可以帮助.
标签:python,text-processing,shell-script 来源: https://codeday.me/bug/20190816/1663713.html