免费注册 查看新帖 |

Chinaunix

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

[文本处理] awk特殊字符作为分隔符问题 [复制链接]

论坛徽章:
1
15-16赛季CBA联赛之同曦
日期:2017-03-19 09:57:50
发表于 2017-11-08 20:25 |显示全部楼层


怎么同时以 "^|" 作为分隔符呢,下面这样貌似不行,尝试给 ^ 字符和 | 转义貌似也不行,

echo "20170926144420^|141^|1^| ^|0^|02^| ^| ^|20^|1^|m00^|0"  | awk -F"^|"  '{print $5}'


除了把 "^|" 中的一个字符替换掉的办法外,有没有其他办法处理这种特殊分隔符呢,还请大神指点一下

论坛徽章:
6
摩羯座
日期:2013-08-24 10:43:10狮子座
日期:2013-08-25 10:27:06天秤座
日期:2013-09-11 20:28:44午马
日期:2014-09-28 16:06:0015-16赛季CBA联赛之八一
日期:2016-12-19 13:55:0515-16赛季CBA联赛之天津
日期:2016-12-20 14:01:23
发表于 2017-11-08 21:06 |显示全部楼层
两个字符都加转意

论坛徽章:
130
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
发表于 2017-11-08 21:54 |显示全部楼层
回复 1# 农民伯伯丶

$ echo "20170926144420^|141^|1^| ^|0^|02^| ^| ^|20^|1^|m00^|0" | awk -F'\\^\\|' '{print $1,$5}'
20170926144420 0

论坛徽章:
1
15-16赛季CBA联赛之同曦
日期:2017-03-19 09:57:50
发表于 2017-11-09 10:29 |显示全部楼层
回复 2# cao627

可以了,多谢

论坛徽章:
1
15-16赛季CBA联赛之同曦
日期:2017-03-19 09:57:50
发表于 2017-11-09 10:38 |显示全部楼层
回复 3# jason680

可以了,谢谢你,不过单双引号转义为啥有点不一样

awk -F'\\^\\|' '{print $33}'     单引号2个反斜杠转义
awk -F"\\\^\\\|" '{print $33}'  双引号3个反斜杠转义

论坛徽章:
1
15-16赛季CBA联赛之同曦
日期:2017-03-19 09:57:50
发表于 2017-11-09 10:39 |显示全部楼层
回复 3# jason680

可以了,谢谢你
使用双引号,需要三个反斜杠

awk -F"\\\^\\\|" '{print $0,$5}'   

论坛徽章:
1
15-16赛季CBA联赛之同曦
日期:2017-03-19 09:57:50
发表于 2017-11-09 10:40 |显示全部楼层
回复 3# jason680

可以了,谢谢你
如果使用双引号,需要使用三个反斜杠

awk -F"\\\^\\\|" '{print $0, $5}'

论坛徽章:
1
15-16赛季CBA联赛之同曦
日期:2017-03-19 09:57:50
发表于 2017-11-09 10:41 |显示全部楼层
回复 3# jason680


可以了,谢谢你
如果使用双引号,需要使用三个反斜杠

awk -F"\\\^\\\|" '{print $0, $5}'

论坛徽章:
1
15-16赛季CBA联赛之同曦
日期:2017-03-19 09:57:50
发表于 2017-11-09 10:41 |显示全部楼层
回复 3# jason680


可以了,谢谢你
如果使用双引号,需要使用三个反斜杠

awk -F"\\\^\\\|" '{print $0, $5}'

论坛徽章:
1
15-16赛季CBA联赛之同曦
日期:2017-03-19 09:57:50
发表于 2017-11-09 10:41 |显示全部楼层
回复 3# jason680


可以了,谢谢你
如果使用双引号,需要使用三个反斜杠

awk -F"\\\^\\\|" '{print $0, $5}'
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

DTCC2020中国数据库技术大会

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

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

http://dtcc.it168.com


大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP