awk:左移、右移、按位取反、按位与、按位或、按位异或、数值IP转字符串IP
2018-01-15 10:34
891 查看
awk中没有左移、右移、按位取反、按位与、按位或、按位异或的操作符,只能用函数。
lshift(val, count)、rshift(val, count)、compl(val)、and(v1, v2)、or(v1, v2)、xor(v1, v2)。
一、左移、右移、取反
1.1 文件内容
1.2 命令与结果
cat 000.txt | awk '{print lshift($1,8), rshift($1,8), compl($1), $1}'
1.3 分析:
原始数据:0x4030201 67305985
左移8位: 0x403020100 17230332160
右移8位: 0x40302 262914
按位取反:0x1FFFFFFBFCFDFE 9007199187435006【这个有点问题,有待进一步分析】
二、按位与、或、异或
2.1 文件内容
2.2 命令与结果
cat 000.txt | awk '{print and($1,$2), or($1,$2), xor($1,$2), $1, $2}'
2.3 分析
原始数据:10 0x1010
3 0x0011
按位与: 2 0x0010
按位或: 11 0x1011
按位异或: 9 0x1001
三、 一个应用实例
3.1 将数值IP(主机字节序),转为字符串IP
cat bb.txt | awk '{ip11=rshift(and($1, 0xFF000000), 24); ip12=rshift(and($1, 0xFF0000), 16); ip13=rshift(and($1, 0xFF00), 8); ip14=and($1, 0xFF); ip21=rshift(and($2,0xFF000000), 24); ip22=rshift(and($2, 0xFF0000), 16); ip23=rshift(and($2,
0xFF00), 8); ip24=and($2, 0xFF); print ip11"."ip12"."ip13"."ip14, ip21"."ip22"."ip23"."ip24, $3;}'
bb.txt:
执行结果:
3.2 将字符串IP,转为数值IP(主机字节序)
cat aa.txt | awk '{split($1, IP1, "."); ip11=lshift(IP1[1],24) + lshift(IP1[2], 16) + lshift(IP1[3], 8) + IP1[4]; split($2, IP2, "."); ip22=lshift(IP2[1], 24) + lshift(IP2[2], 16) + lshift(IP2[3], 8) + IP2[4]; print ip11, ip22, $3; }'
lshift(val, count)、rshift(val, count)、compl(val)、and(v1, v2)、or(v1, v2)、xor(v1, v2)。
一、左移、右移、取反
1.1 文件内容
1.2 命令与结果
cat 000.txt | awk '{print lshift($1,8), rshift($1,8), compl($1), $1}'
1.3 分析:
原始数据:0x4030201 67305985
左移8位: 0x403020100 17230332160
右移8位: 0x40302 262914
按位取反:0x1FFFFFFBFCFDFE 9007199187435006【这个有点问题,有待进一步分析】
二、按位与、或、异或
2.1 文件内容
2.2 命令与结果
cat 000.txt | awk '{print and($1,$2), or($1,$2), xor($1,$2), $1, $2}'
2.3 分析
原始数据:10 0x1010
3 0x0011
按位与: 2 0x0010
按位或: 11 0x1011
按位异或: 9 0x1001
三、 一个应用实例
3.1 将数值IP(主机字节序),转为字符串IP
cat bb.txt | awk '{ip11=rshift(and($1, 0xFF000000), 24); ip12=rshift(and($1, 0xFF0000), 16); ip13=rshift(and($1, 0xFF00), 8); ip14=and($1, 0xFF); ip21=rshift(and($2,0xFF000000), 24); ip22=rshift(and($2, 0xFF0000), 16); ip23=rshift(and($2,
0xFF00), 8); ip24=and($2, 0xFF); print ip11"."ip12"."ip13"."ip14, ip21"."ip22"."ip23"."ip24, $3;}'
bb.txt:
执行结果:
3.2 将字符串IP,转为数值IP(主机字节序)
cat aa.txt | awk '{split($1, IP1, "."); ip11=lshift(IP1[1],24) + lshift(IP1[2], 16) + lshift(IP1[3], 8) + IP1[4]; split($2, IP2, "."); ip22=lshift(IP2[1], 24) + lshift(IP2[2], 16) + lshift(IP2[3], 8) + IP2[4]; print ip11, ip22, $3; }'
相关文章推荐
- awk:左移、右移、按位取反、按位与、按位或、按位异或、数值IP转字符串IP
- 将IP字符串转换成数值(ORACLE)
- awk在何时会自动把数字字符串转换为数值
- 字符串IP地址转换成IP数值函数
- MySQL如何有效的存储IP地址及字符串IP和数值之间如何转换
- 内存中原码,反码,补码,查看数值范围,&,或,异或,取反,左右移位操作
- awk 数值和字符串比较问题
- 字符串IP地址转换成IP数值函数
- 字符串类型ip同数值类型ip转换
- java 判断字符串IP合法性以及获取IP的数值形式
- Shell数值、字符串比较
- 使用 awk 过滤文本或文件中的字符串
- ES6 字符串与数值扩展
- linux shell 编程1文件权限检测、字符串比较判断、数值大小比较、时间获取以及单引号双引号反引号等的使用
- Java对字符串异或加密
- 一个字符串IP分割的处理小程序
- C# DataTable中Compute方法用法集锦(数值/字符串/运算符/表等操作)(转载)
- 给你一组字符串 如 {5,2,3,2,4,5,1,2,1,5},让你输出里面出现次数最多且数值最大的
- MySQL取出数字字符串的一部分,然后按照数值大小排序
- 关于SQL Server中将数值类型转换为字符串的问题[转]