linux awk命令实现对数据的每一列进行求和、求平均
2022/1/15 7:05:05
本文主要是介绍linux awk命令实现对数据的每一列进行求和、求平均,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
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
这篇关于linux awk命令实现对数据的每一列进行求和、求平均的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-18git仓库有更新,jenkins 自动触发拉代码怎么配置的?-icode9专业技术文章分享
- 2024-12-18Jenkins webhook 方式怎么配置指定的分支?-icode9专业技术文章分享
- 2024-12-13Linux C++项目实战入门教程
- 2024-12-13Linux C++编程项目实战入门教程
- 2024-12-11Linux部署Scrapy教程:新手入门指南
- 2024-12-11怎么将在本地创建的 Maven 仓库迁移到 Linux 服务器上?-icode9专业技术文章分享
- 2024-12-10Linux常用命令
- 2024-12-06谁看谁服! Linux 创始人对于进程和线程的理解是…
- 2024-12-04操作系统教程:新手入门及初级技巧详解
- 2024-12-04操作系统入门:新手必学指南