news 2026/1/30 10:41:44

bash中awk如何切分输出

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
bash中awk如何切分输出

在Bash中,使用`awk`切分输出有多种方式。

这里示例几种常见的使用方法。

1 基本字段切割

1.1 按空格/制表符分隔

# 显示第一列
echo "apple banana cherry" | awk '{print $1}'

# 显示第一列和第三列
echo "apple banana cherry date" | awk '{print $1, $3}'

# 显示最后一列
echo "apple banana cherry" | awk '{print $NF}'

# 显示倒数第二列
echo "apple banana cherry date" | awk '{print $(NF-1)}'


1.2 指定分隔符

# 使用 -F 指定分隔符
echo "apple,banana,cherry" | awk -F',' '{print $2}'

# 多个分隔符(正则表达式)
echo "apple;banana:cherry" | awk -F'[;:]' '{print $1, $3}'

# 输出时指定分隔符(OFS)
echo "apple banana cherry" | awk 'BEGIN{OFS=":"} {print $1, $2, $3}'

2 按列宽切割

即按固定宽度切割

# 使用 substr 函数 echo "12345ABCDE" | awk '{print substr($0, 1, 5), substr($0, 6, 5)}' # 更复杂的例子 data="20240101文件1.txt" echo $data | awk '{ date = substr($0, 1, 8) name = substr($0, 9) print "日期:", date, "文件名:", name }'

3 处理复杂文本

# 示例文本 cat <<EOF > data.txt John:Doe:25:New York Jane:Smith:30:Los Angeles Bob:Johnson:35:Chicago EOF # 按冒号分隔,重新格式化输出 awk -F':' '{print "姓名:", $1, $2, "年龄:", $3, "城市:", $4}' data.txt # 条件筛选 + 切割 awk -F':' '$3 > 30 {print $1 " is older than 30"}' data.txt

输出示例如下所示

姓名: John Doe 年龄: 25 城市: New York
姓名: Jane Smith 年龄: 30 城市: Los Angeles
姓名: Bob Johnson 年龄: 35 城市: Chicago
Bob is older than 30

4 高级切割技巧

# 跳过前N行 ls -la | awk 'NR > 3 {print $9}' # 使用正则表达式匹配分隔 echo "apple-123-orange-456" | awk '{split($0, a, /[0-9]+/); print a[1], a[2]}' # 多字段重新组合 echo "2023-12-25" | awk -F'-' '{print "年月日:", $3"/"$2"/"$1}'

5 常用实际案例

5.1 分析系统进程

# 获取前5个内存使用最多的进程 ps aux | sort -rnk 4 | head -5 | awk '{print "进程:", $11, "内存:", $4"%"}'

5.2 分析日志文件

# 统计IP访问次数 cat access.log | awk '{print $1}' | sort | uniq -c | sort -rn

5.3 CSV文件处理

# 处理CSV文件 awk -F',' 'BEGIN {OFS="\t"} {print $1, $3, $5}' data.csv

5.4 提取特定模式

# 提取email地址 echo "联系我: test@example.com 或 admin@site.org" | \ awk '{ for(i=1; i<=NF; i++) if($i ~ /@/) print "Email found:", $i }'

6 使用内置变量

# NF: 字段数 echo "a b c d e" | awk '{print "字段数:", NF}' # NR: 行号 awk '{print "行号", NR, ":", $0}' data.txt # FS: 输入字段分隔符 # OFS: 输出字段分隔符 awk 'BEGIN{FS=":"; OFS="|"} {print $1, $3}' data.txt

7 一行命令实用例子

# 获取磁盘使用率 df -h | awk '/\/dev\/sd/ {print "磁盘", $1, "使用率:", $5}' # 计算文件总大小 ls -l *.txt | awk '{sum += $5} END {print "总大小:", sum/1024, "KB"}' # 提取URL域名 echo "https://www.example.com/path" | awk -F'/' '{print $3}'

8 结合其他命令使用

# 与 cut 对比(awk更灵活) echo "a:b:c:d" | cut -d':' -f2 # 使用cut echo "a:b:c:d" | awk -F':' '{print $2}' # 使用awk # 与 sed 结合 echo "name=value;age=30" | sed 's/;/\n/g' | awk -F'=' '{print $1}'

需要注意的是,在使用awk时,

使用 `-F` 指定输入分隔符

使用 `OFS` 控制输出分隔符

`$0` 表示整行,`$1`、`$2` 等表示各字段

`NF` 是字段总数,`NR` 是当前行号

可以使用正则表达式作为分隔符

简单列提取用`awk`默认空格分隔,固定宽度用`substr`,复杂分隔用`-F`指定分隔符。

reference

---

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/20 3:39:35

如何用M2FP提升电商产品图像处理效率

如何用M2FP提升电商产品图像处理效率 在电商领域&#xff0c;商品展示的核心之一是人物模特图的精细化处理。无论是自动换装、虚拟试衣&#xff0c;还是背景替换与智能裁剪&#xff0c;其前提都是对人物身体各部位进行精准识别与分割。传统图像处理方法依赖人工标注或通用分割模…

作者头像 李华
网站建设 2026/1/29 17:13:59

班次时间自定义 + 备注功能:排班软件的核心交互设计

在智能手机普及的当下&#xff0c;通过手机查看排班远比依赖电脑更为便捷。 这款极简排班工具目前完全免费&#xff1a;用户需先自定义班次的起止时间&#xff0c;完成设置后点击【开始排班】&#xff0c;即可为指定日期分配相应班次&#xff0c;并支持随时【添加备注】。 极简…

作者头像 李华
网站建设 2026/1/29 6:20:36

智能广告投放:基于M2FP的受众特征分析

智能广告投放&#xff1a;基于M2FP的受众特征分析 在数字广告日益精细化的今天&#xff0c;精准识别用户视觉特征已成为提升转化率的关键环节。传统的人群画像多依赖于行为数据与注册信息&#xff0c;而忽视了最直观的视觉线索——用户的外貌、穿着与姿态。随着计算机视觉技术…

作者头像 李华
网站建设 2026/1/23 17:27:48

解析EasyCVR的设备统一管理能力,助力构筑安防融合感知的基石

在万物互联的智能时代&#xff0c;企业面临的安防挑战不再是缺少摄像头&#xff0c;而是如何高效管理成百上千、品牌各异、协议不同的视频设备。设备管理能力&#xff0c;直接决定了整个视频监控体系的稳定性和可用性。本文将深度剖析EasyCVR视频融合平台在设备管理方面的核心功…

作者头像 李华
网站建设 2026/1/31 3:09:08

M2FP模型训练数据准备:标注与增强技巧

M2FP模型训练数据准备&#xff1a;标注与增强技巧 &#x1f4cc; 引言&#xff1a;为何高质量数据是M2FP成功的基石&#xff1f; 在构建高性能的多人人体解析系统时&#xff0c;模型架构固然重要&#xff0c;但真正决定其泛化能力与实际表现的关键——在于训练数据的质量。M2…

作者头像 李华
网站建设 2026/1/30 16:10:38

M2FP模型灰度发布方案

M2FP模型灰度发布方案&#xff1a;多人人体解析服务的渐进式上线实践 &#x1f4cc; 背景与挑战&#xff1a;从单点部署到稳定交付 在AI模型产品化过程中&#xff0c;直接全量上线新模型往往伴随巨大风险。尤其对于M2FP这类高复杂度语义分割模型&#xff0c;其输出直接影响下…

作者头像 李华