linux awk命令实现输出每一列数据的最大值、最小值
1、测试数据
root@PC1:/home/test# ls test.txt root@PC1:/home/test# cat test.txt 3 4 2 2 1 9 5 7 5 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 2 1 9 5 7 5 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 temp=$(head -n 1 test.txt | awk -v a=$i '{print $a}'); awk -v b=$i -v c=$temp 'BEGIN{max = c} {if($b > max) {max = $b}} END {print max}' test.txt >> max.txt; done root@PC1:/home/test# ls max.txt test.txt root@PC1:/home/test# cat max.txt 5 9 8 7 root@PC1:/home/test# paste -d " " -s max.txt ## 转换为行的形式 5 9 8 7
3、输出每一列的最小值
root@PC1:/home/test# ls test.txt root@PC1:/home/test# cat test.txt 3 4 2 2 1 9 5 7 5 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 temp=$(head -n 1 test.txt | awk -v a=$i '{print $a}'); awk -v b=$i -v c=$temp 'BEGIN{min = c} {if($b < min) {min = $b}} END {print min}' test.txt >> min.txt; done root@PC1:/home/test# ls min.txt test.txt root@PC1:/home/test# cat min.txt 1 3 2 2 root@PC1:/home/test# paste -d " " -s min.txt ## 转换为列的形式 1 3 2 2
4、R语言实现
dir() dat <- read.table("test.txt", header = F) dat apply(dat, 2, max) apply(dat, 2, min)
> dir() [1] "test.txt" > dat <- read.table("test.txt", header = F) ## 读取测试数据 > dat V1 V2 V3 V4 1 3 4 2 2 2 1 9 5 7 3 5 7 8 4 4 2 3 4 6 > apply(dat, 2, max) ## 求每一列的最大值 V1 V2 V3 V4 5 9 8 7 > apply(dat, 2, min) ## 求每一列的最小值 V1 V2 V3 V4 1 3 2 2
分类:
linux shell
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律