码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Linux小技巧之awk必知必会


    在这里插入图片描述
    Linux Shell 三剑客之一,废话不多说直接上干货。

    目录

      • 1. 指定分隔符
      • 2.指定打印行数
      • 3.打印最后一列
      • 4.打印倒数第二列
      • 5.匹配输出
      • 6.if 判断
      • 7.统计列总数值
      • 8.时间格式转换

    示例数据:
    在这里插入图片描述

    1. 指定分隔符

    awk -F '|' '{print $1}' log.txt

    # awk -F '|' '{print $1}' log.txt
    tbname
    =================================================================
    tb_7456_cm1eM
    tb_7456_cm1e0
    tb_7456_1bg3J
    tb_7456_1dXax
    tb_7456_1b9ol
    tb_7456_1bhdH
    tb_7456_1eAYV
    tb_7456_1fxkg
    tb_7456_1fZRW
    tb_7456_cm1ez
    tb_7456_1bg3J
    tb_7456_cm1hX
    tb_7456_cm1ck
    tb_7456_cm1ck
    tb_7456_cm1ck
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    2.指定打印行数

    awk -F '|' 'NR>2 {print $1}' log.txt

    # awk -F '|' 'NR>2 {print $1}' log.txt
    tb_7456_cm1eM
    tb_7456_cm1e0
    tb_7456_1bg3J
    tb_7456_1dXax
    tb_7456_1b9ol
    tb_7456_1bhdH
    tb_7456_1eAYV
    tb_7456_1fxkg
    tb_7456_1fZRW
    tb_7456_cm1ez
    tb_7456_1bg3J
    tb_7456_cm1hX
    tb_7456_cm1ck
    tb_7456_cm1ck
    tb_7456_cm1ck
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    3.打印最后一列

    awk -F '|' 'NR>2 {print $NF}' log.txt

    # awk -F '|' 'NR>2 {print $NF}' log.txt
            1532
              13
             209
           56556
            3334
            7611
           48109
               3
            1668
            7249
             145
              22
               6
               1
             506
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    4.打印倒数第二列

    awk -F '|' 'NR>2 {print $(NF-1)}' log.txt

    # awk -F '|' 'NR>2 {print $(NF-1)}' log.txt
         108
         350
         293
          57
         207
         316
          26
          27
         148
         203
          18
         480
          64
          20
         348
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    5.匹配输出

    awk -F '|' '/cm1e/ {print $1}' log.txt

    # awk -F '|' '/cm1e/ {print $1}' log.txt
    tb_7456_cm1eM
    tb_7456_cm1e0
    tb_7456_cm1ez
    
    • 1
    • 2
    • 3
    • 4

    6.if 判断

    awk -F '|' '{if ($3<100) print $0 }' log.txt

    # awk -F '|' '{if ($3<100) print $0 }' log.txt
    tbname         | create_time             |     cols|        rows
    =================================================================
    tb_7456_1dXax  | 2023-03-21 05:38:44.400 |      57 |       56556
    tb_7456_1eAYV  | 2023-03-21 03:50:16.347 |      26 |       48109
    tb_7456_1fxkg  | 2023-03-21 03:50:15.484 |      27 |           3
    tb_7456_1bg3J  | 2023-09-05 12:42:18.269 |      18 |         145
    tb_7456_cm1ck  | 2023-09-05 02:03:43.843 |      64 |           6
    tb_7456_cm1ck  | 2023-03-21 03:50:19.610 |      20 |           1
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    # awk -F '|' '/cm1/ {if ($3<100) print $1"\t"$3 }' log.txt
    tb_7456_cm1ck         64
    tb_7456_cm1ck         20
    
    • 1
    • 2
    • 3

    7.统计列总数值

    awk -F '|' 'NR>2 {sum+=$3} END {print sum}' log.txt

    # awk -F '|' 'NR>2 {sum+=$3} END {print sum}' log.txt
    2665
    
    • 1
    • 2

    8.时间格式转换

    awk '{print strftime("%Y-%m-%d %T",1697848286)}'

    # date +%s |awk '{print strftime("%Y-%m-%d %T",$1)}'
    2023-10-21 08:32:44
    
    • 1
    • 2
  • 相关阅读:
    2023年【电工(高级)】报名考试及电工(高级)模拟考试题
    Facebook广告账户被封的可能原因及应如何避免?
    GESP 四级急救包(1):指针与地址
    深入理解SqueezeSegV3点云分割
    cs231n--正则化与优化
    【JAVA】-- 简易超市管理系统窗口(五)(实现思路+每步代码)
    基于matlab的SVR回归模型
    【NLP练习】调用Gensim库训练Word2Vec模型
    【react native】模拟mock接口
    九、【VUE-CLI】浏览器本地存储(待办事项案例 · 第二版)
  • 原文地址:https://blog.csdn.net/weixin_43700866/article/details/133957013
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号