我有一个包含25个段落的文件,它们之间用空白行隔开,每个段落大约2至20行,每行有5列,中间用分号分隔.如何将第2段移到第1段的右下3第2段的下一个权利,依此类推.
我的目标是稍后将所有内容粘贴到Excel中.
此处使用的数字仅是任何单词/数字的示例.
111; 111; 111; 111; 111;
111; 111; 111; 111; 111;
222; 222; 222; 222; 222;
222; 222; 222; 222; 222;
222; 222; 222; 222; 222;
333; 333; 333; 333; 333;
333; 333; 333; 333; 333;
333; 333; 333; 333; 333;
333; 333; 333; 333; 333;
所需的输出:
111;111;111;111;111; 222;222;222;222;222; 333;333;333;333;333;
111;111;111;111;111; 222;222;222;222;222; 333;333;333;333;333;
222;222;222;222;222; 333;333;333;333;333;
333;333;333;333;333;
解决方法:
看看我对How to move everything following a dash to a new column?的回答.
如果您的解决方案不需要基于awk,则以下代码可能会满足您的要求:
csplit -f tempfile in.txt '/^\s*$/+1' {*}; paste tempfile* > out.txt
您的样本数据的输出是
111;111;111;111;111; 222;222;222;222;222; 333;333;333;333;333;
111;111;111;111;111; 222;222;222;222;222; 333;333;333;333;333;
222;222;222;222;222; 333;333;333;333;333;
333;333;333;333;333;
如您所见,制表符将各列分开,如果您要对out.txt进行一些后处理,则是个好主意.
如果需要awk解决方案,则可以通过以下方法获得与上述相同的结果:
awk 'BEGIN{FS="\n"; RS="\n\n";}
{for(i=1; i<= NF;i++)
ar[NR,i]=$i
nf = nf <NF? NF : nf}
END{ for(j=1; j <= nf; j++){
str=""
for(i = 1; i <= NR; i++){
str = str""ar[i,j]"\t"
}
print str
}
}' in.txt
但是,如果您想使人眼看起来更好,则必须添加一些其他代码(例如,确定每列中最长的字段,填充所有其他条目,…)以获取所需的内容.
标签:awk,linux 来源: https://codeday.me/bug/20191119/2034692.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。