标签:sum PC1 awk 一列 linux test home txt root
1、测试数据
root@PC1:/home/test# ls test.txt root@PC1:/home/test# cat test.txt 3 4 2 9 1 3 5 4 3 7 8 4 2 3 4 6
2、对每一列数据进行求和
root@PC1:/home/test# ls test.txt root@PC1:/home/test# cat test.txt 3 4 2 9 1 3 5 4 3 7 8 4 2 3 4 6 root@PC1:/home/test# for i in `head -n 1 test.txt | awk '{print NF}' | xargs seq`; do awk -v a=$i 'BEGIN{sum = 0} {sum += $a} END{print sum}' test.txt >> sum.txt; done root@PC1:/home/test# ls sum.txt test.txt root@PC1:/home/test# cat sum.txt ##求和结果保存为列的形式 9 17 19 23 root@PC1:/home/test# paste -d " " -s sum.txt ## 将列的形式转换为行的形式 9 17 19 23
3、对每一列求平均
root@PC1:/home/test# ls test.txt root@PC1:/home/test# cat test.txt 3 4 2 9 1 3 5 4 3 7 8 4 2 3 4 6 root@PC1:/home/test# for i in `head -n 1 test.txt | awk '{print NF}' | xargs seq `; do awk -v a=$i 'BEGIN{sum = 0} {sum += $a} END {print sum/NR}' test.txt >> mean.txt; done root@PC1:/home/test# ls mean.txt test.txt root@PC1:/home/test# cat mean.txt 2.25 4.25 4.75 5.75 root@PC1:/home/test# paste -d " " -s mean.txt ## 每一列求平均结果 2.25 4.25 4.75 5.75
4、R语言实现
dir() dat <- read.table("test.txt", header = F) dat apply(dat, 2, sum) apply(dat, 2, mean)
> dir() [1] "test.txt" > dat <- read.table("test.txt", header = F) ## 读取测试数据 > dat V1 V2 V3 V4 1 3 4 2 9 2 1 3 5 4 3 3 7 8 4 4 2 3 4 6 > apply(dat, 2, sum) ## 求每一列的和 V1 V2 V3 V4 9 17 19 23 > apply(dat, 2, mean) ## 求每一列的平均数 V1 V2 V3 V4 2.25 4.25 4.75 5.75
标签:sum,PC1,awk,一列,linux,test,home,txt,root 来源: https://www.cnblogs.com/liujiaxin2018/p/15804970.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。