标签:python text-processing shell-script
我有一个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
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。