免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4311 | 回复: 16

[文本处理] MAC地址自动补0? [复制链接]

论坛徽章:
0
发表于 2014-01-06 11:31 |显示全部楼层
如下的WWN和MAC地址:
20:1:54:7f:ee:c1:28:40
0:9:f:46:ce:5f
64:87:88:15:d0:7

我想把它们转化成XX:XX:XX:XX:XX的格式,不足XX的自动在前面补0,如下:
20:01:54:7f:ee:c1:28:40
00:09:0f:46:ce:5f
64:87:88:15:d0:07

论坛徽章:
0
发表于 2014-01-06 11:51 |显示全部楼层
本帖最后由 yaozhibing41001 于 2014-01-06 11:56 编辑

ca回复 1# netocool
  1. awk -F: '{for(i=1;i<=NF;i++)printf length($i)==1? "0"$i":":$i":";print "" }' file|sed 's/:$//g'
复制代码

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
发表于 2014-01-06 11:52 |显示全部楼层
本帖最后由 这个冬天不冷 于 2014-01-06 11:55 编辑
  1. [root@everIover ~]# awk -F ":" '{for(i=1;i<NF;i++){;if(length($i)==1)printf("0%s:",$i);else printf("%s:",$i)}if(length($i)==1)print "0"$NF;else print $NF}' i
  2. 20:01:54:7f:ee:c1:28:40
  3. 00:09:0f:46:ce:5f
  4. 64:87:88:15:d0:07
  5. [root@everIover ~]#
  6. [root@everIover ~]# cat i
  7. 20:1:54:7f:ee:c1:28:40
  8. 0:9:f:46:ce:5f
  9. 64:87:88:15:d0:7
  10. [root@everIover ~]#
复制代码

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
发表于 2014-01-06 12:04 |显示全部楼层
本帖最后由 yestreenstars 于 2014-01-06 13:10 编辑
  1. awk -vRS='[:\n]' '{printf "%02s%s",$0,RT}'
复制代码
  1. sed 's/\b[^:]\b/0&/g'
复制代码

论坛徽章:
507
金牛座
日期:2014-02-26 17:49:58水瓶座
日期:2014-02-26 18:10:15白羊座
日期:2014-04-15 19:29:52寅虎
日期:2014-04-17 19:43:21酉鸡
日期:2014-04-19 21:24:10子鼠
日期:2014-04-22 13:55:24卯兔
日期:2014-04-22 14:20:58亥猪
日期:2014-04-22 16:13:09狮子座
日期:2014-05-05 22:31:17摩羯座
日期:2014-05-06 10:32:53处女座
日期:2014-05-12 09:23:11子鼠
日期:2014-05-21 18:21:27
发表于 2014-01-06 12:05 |显示全部楼层
本帖最后由 Herowinter 于 2014-01-06 12:05 编辑

回复 1# netocool
  1. awk --re-interval -vFS=':' -vOFS=':' '{for(i=1;i<=NF;i++)if($i!~/[0-9a-f]{2}/)$i="0"$i}1' i

  2. 20:01:54:7f:ee:c1:28:40
  3. 00:09:0f:46:ce:5f
  4. 64:87:88:15:d0:07
复制代码

论坛徽章:
50
15-16赛季CBA联赛之广夏
日期:2018-11-05 09:42:462015年亚冠纪念徽章
日期:2015-07-23 11:58:122015亚冠之广州富力
日期:2015-07-07 08:26:172015亚冠之塔什干棉农
日期:2015-06-29 09:08:072015年亚洲杯之伊朗
日期:2015-03-08 20:51:012015年迎新春徽章
日期:2015-03-04 09:58:11未羊
日期:2014-10-16 22:41:47处女座
日期:2014-10-16 15:33:33酉鸡
日期:2014-03-13 12:54:10巳蛇
日期:2014-03-10 14:39:052015亚冠之德黑兰石油
日期:2015-07-29 12:46:372015亚冠之德黑兰石油
日期:2015-08-07 12:54:11
发表于 2014-01-06 12:21 |显示全部楼层
  1. awk '{gsub(/\<[^:]\>/,"0&")}1'
复制代码

论坛徽章:
50
15-16赛季CBA联赛之广夏
日期:2018-11-05 09:42:462015年亚冠纪念徽章
日期:2015-07-23 11:58:122015亚冠之广州富力
日期:2015-07-07 08:26:172015亚冠之塔什干棉农
日期:2015-06-29 09:08:072015年亚洲杯之伊朗
日期:2015-03-08 20:51:012015年迎新春徽章
日期:2015-03-04 09:58:11未羊
日期:2014-10-16 22:41:47处女座
日期:2014-10-16 15:33:33酉鸡
日期:2014-03-13 12:54:10巳蛇
日期:2014-03-10 14:39:052015亚冠之德黑兰石油
日期:2015-07-29 12:46:372015亚冠之德黑兰石油
日期:2015-08-07 12:54:11
发表于 2014-01-06 12:23 |显示全部楼层
回复 4# yestreenstars


    awk的有问题。

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
发表于 2014-01-06 13:11 |显示全部楼层
回复 7# WilliBhamlll
多谢,已改~

   

论坛徽章:
50
15-16赛季CBA联赛之广夏
日期:2018-11-05 09:42:462015年亚冠纪念徽章
日期:2015-07-23 11:58:122015亚冠之广州富力
日期:2015-07-07 08:26:172015亚冠之塔什干棉农
日期:2015-06-29 09:08:072015年亚洲杯之伊朗
日期:2015-03-08 20:51:012015年迎新春徽章
日期:2015-03-04 09:58:11未羊
日期:2014-10-16 22:41:47处女座
日期:2014-10-16 15:33:33酉鸡
日期:2014-03-13 12:54:10巳蛇
日期:2014-03-10 14:39:052015亚冠之德黑兰石油
日期:2015-07-29 12:46:372015亚冠之德黑兰石油
日期:2015-08-07 12:54:11
发表于 2014-01-06 13:48 |显示全部楼层
回复 8# yestreenstars

好像还是有问题,你看看第二行。
   

论坛徽章:
7
亥猪
日期:2013-10-10 17:00:29辰龙
日期:2013-10-12 16:23:19卯兔
日期:2013-11-18 17:01:27金牛座
日期:2014-09-09 10:17:052015七夕节徽章
日期:2015-08-21 11:06:172015亚冠之柏太阳神
日期:2015-09-25 13:56:42数据库技术版块每日发帖之星
日期:2016-08-06 06:20:00
发表于 2014-01-06 13:58 |显示全部楼层
本帖最后由 li0924 于 2014-01-06 14:21 编辑
  1. awk -F: '{for(i=1;i<NF;i++)printf("%02s:",$i);printf("%02s\n",$NF)}'
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

DTCC2020中国数据库技术大会

【架构革新 高效可控】2020年12月21日-23日第十一届中国数据库技术大会将在北京隆重召开。

大会设置2大主会场,20+技术专场,将邀请超百位行业专家,重点围绕数据架构、AI与大数据、传统企业数据库实践和国产开源数据库等内容展开分享和探讨,为广大数据领域从业人士提供一场年度盛会和交流平台。

http://dtcc.it168.com


大会官网>>
  

北京盛拓优讯信息技术有限公司. 版权所有 16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122
中国互联网协会会员  联系我们:huangweiwei@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP