Linux三剑客awk提取网卡IP地址

本文详细介绍了awk命令在Linux系统中如何用于提取网卡IP地址,包括基本用法、模式匹配、IP地址提取和官方命令提示,展示了awk的强大文本处理能力。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Linux三剑客awk提取网卡IP地址

awk介绍

AWK(American Standard Code for Information Interchange)是一种基于文本的Unix/Linux命令行程序,用于文本处理、数据分析和输出操作。AWK通过使用模式来搜索文本数据,然后执行相应的操作。

AWK的语法结构类似于编程语言,包括输入文件、标准输入、输出文件和模式。模式可以是单个字符、多个字符或字符串,也可以是通配符。AWK还支持变量、数组和条件语句。

以下是AWK的一些常见用法:

  1. 打印指定的文件或目录中的所有行:

    awk ‘{print}’ filename

  2. 查找指定模式的文件或目录中的所有行:

    awk ‘pattern’ filename

  3. 打印文件中满足条件的行:

    awk ‘{if (condition) {print}}’ filename

  4. 处理文本数据:

    awk ‘{printf(“%.2f\n”, value)}’ filename

  5. 将文本数据存储到数组中:

    awk ‘{print arr[NR]}’ filename

  6. 对数组中的数据进行处理:

    awk ‘{print $1, $2, $3}’ filename

awk提取网卡IP信息

使用awk命令来提取Linux系统中的网卡IP地址。

假设您想要提取网卡名为ens33的主机上的网卡IP地址,可以执行以下命令:

  • ip addr 命令用于显示网络接口的配置信息
[root@server ~]# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
    link/ether 00:50:56:26:c7:ed brd ff:ff:ff:ff:ff:ff
    inet 192.168.100.128/24 brd 192.168.100.255 scope global noprefixroute ens33
       valid_lft forever preferred_lft forever
    inet6 fe80::525:e4dd:a785:f655/64 scope link noprefixroute
       valid_lft forever preferred_lft forever
  • grep inet 用于过滤出包含 inet 的行,即显示所有的 IPv4IPv6 地址信息。
[root@server ~]# ip addr | grep inet
    inet 127.0.0.1/8 scope host lo
    inet6 ::1/128 scope host
    inet 192.168.100.128/24 brd 192.168.100.255 scope global noprefixroute ens33
    inet6 fe80::525:e4dd:a785:f655/64 scope link noprefixroute
  • awk ‘{print$2}’ 用于提取每行的第二个字段,即 IP 地址和子网掩码。
    [root@server ~]# ip addr |grep inet | awk '{print$2}' |awk -F '/' '{print$1}'
    127.0.0.1
    ::1
    192.168.100.128
    fe80::525:e4dd:a785:f655
    
  • awk -F ‘/’ ‘{print$1}’ 用于通过 “/” 分隔符将 IP 地址和子网掩码分开,并提取 IP 地址部分。
    [root@server ~]# ip addr |grep inet | awk '{print$2}' |awk -F '/' '{print$1}'
    127.0.0.1
    ::1
    192.168.100.128
    fe80::525:e4dd:a785:f655
  • 只提取ens33网卡IP地址
    [root@server ~]# ip addr |grep inet | awk 'NR==3 {print$2}' |awk -F '/' '{print$1}'
    192.168.100.128

官方命令提示

[root@server ~]# awk
Usage: awk [POSIX or GNU style options] -f progfile [–] file …
Usage: awk [POSIX or GNU style options] [–] ‘program’ file …
POSIX options: GNU long options: (standard)
-f progfile --file=progfile
-F fs --field-separator=fs
-v var=val --assign=var=val
Short options: GNU long options: (extensions)
-b --characters-as-bytes
-c --traditional
-C --copyright
-d[file] --dump-variables[=file]
-e ‘program-text’ --source=‘program-text’
-E file --exec=file
-g --gen-pot
-h --help
-L [fatal] --lint[=fatal]
-n --non-decimal-data
-N --use-lc-numeric
-O --optimize
-p[file] --profile[=file]
-P --posix
-r --re-interval
-S --sandbox
-t --lint-old
-V --version
To report bugs, see node `Bugs’ in `gawk.info’, which is
section `Reporting Problems and Bugs’ in the printed version.

gawk is a pattern scanning and processing language.
By default it reads standard input and writes standard output.

Examples:
gawk '{ sum += $1 }; END { print sum }' file
gawk -F: '{ print $1 }' /etc/passwd

总结

本文介绍了AWK是一种基于文本的Unix/Linux命令行程序,用于文本处理、数据分析和输出操作。AWK通过使用模式来搜索文本数据,然后执行相应的操作。
文章列举了一些AWK的常见用法,包括打印指定文件或目录中的所有行,查找指定模式的文件或目录中的所有行,打印满足条件的行,处理文本数据,将数据存储到数组中,对数组中的数据进行处理等。AWK是一种强大的工具,可以处理各种类型的文本数据,熟练掌握AWK可以帮助用户更轻松地处理和分析数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

清醒云思

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值