在用awk处理文本时,有些场景需要将简化的IPV6地址补充成完整的IPV6地址,下边函数可简单实现:

  • IPV6地址补全函数
# ipv6地址补全函数
function compipv6(orig_address){
# 分割IPV6地址
split(orig_address, ipv6_addr, "/")
n = split(ipv6_addr[1], ip_field, ":")
full_addr=""
# 切割简化的地址
split(ipv6_addr[1], ip_field, ":")
# 每个字段不足4位则高位补0
for ( i=1; i<=n; i++){
if ( length(ip_field[i]) == 0 ){
ip_field[i] = "0000"
}
else if ( length(ip_field[i]) == 1 ){
ip_field[i] = "000"ip_field[i]
}
else if ( length(ip_field[i]) == 2 ){
ip_field[i] = "00"ip_field[i]
}
else if ( length(ip_field[i]) == 3 ){
ip_field[i] = "0"ip_field[i]
}
# 组合临时简化的IPV6地址
if ( i==1 ){
full_addr = ip_field[i]
}else{
full_addr = full_addr":"ip_field[i]
}
}
# 循环补全32位
do{
FS = ":"
$0 = full_addr
if( $(NF-1) == "0000" && $NF == "0000" ){
n1 = 8-NF
for ( i=1; i<=n1; i++ ){
full_addr=full_addr":0000"
}
}
else if( $NF != "0000" ){
n1 = 8-NF
for ( i=1; i<=n1; i++ ){
full_addr=gensub(/0000/,"0000:0000",1,full_addr)
}
}
FS=" "
}while(0)
# 判断原始数据是否有掩码位,有则需要返回掩码位
if (orig_address !~ /\//){
return full_addr
}
else{
return full_addr"/"ipv6_addr[2]
}
}
  • 需要解析适配的源数据
 vrf ChinaMobile_SGi
rd 24059:4600
address-family ipv6 unicast
network 2409:8005:800::/127
network 2409:8005:800::8/127
network 2409:8005:800::10/127
network 2409:8005:800::1c/127
network 2409:8005:800::24/127
network 2409:8015:800::/120
network 2409:8015:800::100/120
network 2409:8015:800:1::/64
network 2409:8015:800:2::/64
network 2409:8015:870::/44
network 2409:8015:880::/43
network 2409:8127:f200::/44
network 2409:8127:f210::/44
network 2409:8127:f220::/44
network 2409:8127:f240::/44
network 2409:8805:800::/43
network 2409:8805:820::/43
network 2409:8805:840::/44
network 2409:8805:850::/44
network 2409:8805:860::/43
network 2409:8805:8a0::/43
network 2409:8805:8c0::/43
!
!
  • awk完整程序
#!/bin/awk -f
# author: wholj
# date: 2018-12-21 # ipv6地址补全函数
function compipv6(orig_address){
# 分割IPV6地址
split(orig_address, ipv6_addr, "/")
n = split(ipv6_addr[1], ip_field, ":")
full_addr=""
# 切割简化的地址
split(ipv6_addr[1], ip_field, ":")
# 每个字段不足4位则高位补0
for ( i=1; i<=n; i++){
if ( length(ip_field[i]) == 0 ){
ip_field[i] = "0000"
}
else if ( length(ip_field[i]) == 1 ){
ip_field[i] = "000"ip_field[i]
}
else if ( length(ip_field[i]) == 2 ){
ip_field[i] = "00"ip_field[i]
}
else if ( length(ip_field[i]) == 3 ){
ip_field[i] = "0"ip_field[i]
}
# 组合临时简化的IPV6地址
if ( i==1 ){
full_addr = ip_field[i]
}else{
full_addr = full_addr":"ip_field[i]
}
}
# 循环补全32位
do{
FS = ":"
$0 = full_addr
if( $(NF-1) == "0000" && $NF == "0000" ){
n1 = 8-NF
for ( i=1; i<=n1; i++ ){
full_addr=full_addr":0000"
}
}
else if( $NF != "0000" ){
n1 = 8-NF
for ( i=1; i<=n1; i++ ){
full_addr=gensub(/0000/,"0000:0000",1,full_addr)
}
}
FS=" "
}while(0)
return full_addr"/"ipv6_addr[2]
} # awk开始处理传入的文本文件
{
# 将文件中的\r换行替换为\n
gsub("\r","\n",$0)
if( NF==2 && $1~/network/ ){
# 调用补全函数将IPV6地址补全
print $2" --> "compipv6($2)
}
}
  • 解析适配结果
2409:8005:800::/127 --> 2409:8005:0800:0000:0000:0000:0000:0000/127
2409:8005:800::8/127 --> 2409:8005:0800:0000:0000:0000:0000:0008/127
2409:8005:800::10/127 --> 2409:8005:0800:0000:0000:0000:0000:0010/127
2409:8005:800::1c/127 --> 2409:8005:0800:0000:0000:0000:0000:001c/127
2409:8005:800::24/127 --> 2409:8005:0800:0000:0000:0000:0000:0024/127
2409:8015:800::/120 --> 2409:8015:0800:0000:0000:0000:0000:0000/120
2409:8015:800::100/120 --> 2409:8015:0800:0000:0000:0000:0000:0100/120
2409:8015:800:1::/64 --> 2409:8015:0800:0001:0000:0000:0000:0000/64
2409:8015:800:2::/64 --> 2409:8015:0800:0002:0000:0000:0000:0000/64
2409:8015:870::/44 --> 2409:8015:0870:0000:0000:0000:0000:0000/44
2409:8015:880::/43 --> 2409:8015:0880:0000:0000:0000:0000:0000/43
2409:8127:f200::/44 --> 2409:8127:f200:0000:0000:0000:0000:0000/44
2409:8127:f210::/44 --> 2409:8127:f210:0000:0000:0000:0000:0000/44
2409:8127:f220::/44 --> 2409:8127:f220:0000:0000:0000:0000:0000/44
2409:8127:f240::/44 --> 2409:8127:f240:0000:0000:0000:0000:0000/44
2409:8805:800::/43 --> 2409:8805:0800:0000:0000:0000:0000:0000/43
2409:8805:820::/43 --> 2409:8805:0820:0000:0000:0000:0000:0000/43
2409:8805:840::/44 --> 2409:8805:0840:0000:0000:0000:0000:0000/44
2409:8805:850::/44 --> 2409:8805:0850:0000:0000:0000:0000:0000/44
2409:8805:860::/43 --> 2409:8805:0860:0000:0000:0000:0000:0000/43
2409:8805:8a0::/43 --> 2409:8805:08a0:0000:0000:0000:0000:0000/43
2409:8805:8c0::/43 --> 2409:8805:08c0:0000:0000:0000:0000:0000/43

awk函数实现将简化IPV6地址补全的更多相关文章

  1. Nginx 自动补全url地址补全最后的斜线

    参考地址: http://blog.csdn.net/dong123dddd/article/details/51660368 location /riskcontrol { root /data; ...

  2. TCL函数“参数自动补全” 与 “help 信息显示”

    tcl 函数参数自动补全和 help 信息显示 在EDA tool 中使用命令时,命令的参数可以通过 tab 键自动补全,而且可以使用 -help 显示帮助信息,使用起来很方便: 那么我们自己编写的 ...

  3. Shell脚本中实现自动补全功能

    对于Linuxer来说,自动补全是再熟悉不过的一个功能了.当你在命令行敲下部分的命令时,肯定会本能地按下Tab键补全完整的命令,当然除了命令补全之外,还有文件名补全. Bash-completion ...

  4. Bash的自动补全

    内置补全命令 Bash内置两个补全命令,分别是compgen和complete.compgen命令根据不同的参数,生成匹配单词的候选补全列表,例子如下: monster@monster-Z:~$ co ...

  5. 使用Linux自定义自动补全命令完善自己的shell脚本

    对于Linuxer来说,自动补全是再熟悉不过的一个功能了.当你在命令行敲下部分的命令时,肯定会本能地按下Tab键补全完整的命令,当然除了命令补全之外,还有文件名补全. Bash-completion ...

  6. eclipse代码自动补全。

    打开 Eclipse -> Window -> Perferences 找到Java 下的 Editor 下的 Content Assist , 右边出现的选项中,有一个Auto acti ...

  7. Python3设置在shell脚本中自动补全功能的方法

    本篇博客将会简短的介绍,如何在ubuntu中设置python自动补全功能. 需求:由于python中的内建函数较多,我们在百纳乘时,可能记不清函数的名字,同时自动补全功能,加快了我们开发的效率. 方法 ...

  8. 编写 Bash 补全脚本

    编写 Bash 补全脚本   对于Linuxer来说,自动补全是再熟悉不过的一个功能了.当你在命令行敲下部分的命令时,肯定会本能地按下Tab键补全完整的命令,当然除了命令补全之外,还有文件名补全. B ...

  9. MyCLI :一个支持自动补全和语法高亮的 MySQL/MariaDB 客户端

    MyCLI 是一个易于使用的命令行客户端,可用于受欢迎的数据库管理系统 MySQL.MariaDB 和 Percona,支持自动补全和语法高亮.它是使用 prompt_toolkit 库写的,需要 P ...

随机推荐

  1. JavaDay1(下)

    Java learning_Day1(上) 正式开始JavaSE的基础学习 本人学习视频用的是马士兵的,也在这里献上 <链接:https://pan.baidu.com/s/1qKNGJNh0G ...

  2. AcWing 1014. 登山

    #include<iostream> using namespace std ; ; int f[N],g[N]; int w[N]; int main() { int n; cin> ...

  3. Codeforces Round #601 (Div. 2) C League of Leesins

    把每一次输入的一组数字存下来,然后把每个数字出现的组数存下来 然后找只出现过一次的数字a,那么这个数字a不是开头就是结尾,默认为开头(是哪个都无所谓),然后去找和它出现在同一组的两个数字b和c,而b和 ...

  4. SGD 讲解,梯度下降的做法,随机性。理解反向传播

    SGD 讲解,梯度下降的做法,随机性.理解反向传播 待办 Stochastic Gradient Descent 随机梯度下降没有用Random这个词,因为它不是完全的随机,而是服从一定的分布的,只是 ...

  5. 大二组队(NABCD)

    (Need)需求 很多时候,外人都不了解我们的校园.为了宣传铁大.让更多人了解校园.走进铁大. (Approach)做法 我们有最基本的展示.对校园风貌有基本的讲解.有论坛供应大家讨论. (Benef ...

  6. docker installation and usage

    From 一.环境配置的难题 软件开发最大的麻烦事之一,就是环境配置.用户计算机的环境都不相同,你怎么知道自家的软件,能在那些机器跑起来? 用户必须保证两件事:操作系统的设置,各种库和组件的安装.只有 ...

  7. leetcode 869. Reordered Power of 2

    function reorderedPowerOf2(N) { var a1 = N.toString().split('') a1.sort((a, b) => a.localeCompare ...

  8. 大数据-HBase

    HBase HBase(Hadoop Database)基于Google的BigTable论文,依赖HDFS进行存储.适合存储大体量数据.HBase是高可靠性(数据安全).高性能(存取效率).面向列. ...

  9. DOJ1187 : 重建家园 (分数规划 && 二分 && kruskal)

    最优答案一定是一颗树 那么二分比值,不断kruskal找到最大可以满足的解就可以了 代码如下 #include <cstdio> #include <algorithm> us ...

  10. Linux - cron - 基础

    概述 cron 相关的理解与使用 背景 最近实在没啥写的了 我写东西, 一般是是这些 看了书过后, 做一些系统的整理 比如之前的 docker 和 git 系列 遇到了实际问题, 解决过程也不是那么顺 ...