免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2250 | 回复: 8

[文本处理] 格式化取每行内容,但是其中一项有空格等字符 [复制链接]

论坛徽章:
0
发表于 2014-12-24 09:13 |显示全部楼层

请教下各位,以下的格式,我需要取每一行的内容出来。
由于格式比较固定,我之前是用C的格式化输入用空格分割可以取到,但是最近发现第一行的内容取不到,因为my network中间有空格,请教各位大神用awk或者grep如何匹配啊?


CHANNEL      SSID          KEY    SIGNAL
1            my network    WPA      88
6         ORANGEnetwork    WPA      88
13         network222222    WPA      88
10         applbbbnetwork    WPA      88
1         applFFFnetwork    WPA      88


谢谢!!

论坛徽章:
7
申猴
日期:2014-12-21 13:57:24巳蛇
日期:2014-12-25 22:27:08申猴
日期:2015-01-19 08:07:36辰龙
日期:2015-02-04 11:40:06处女座
日期:2015-02-04 11:40:412015年亚洲杯之卡塔尔
日期:2015-03-06 12:01:322015年亚洲杯之乌兹别克斯坦
日期:2015-03-31 13:43:57
发表于 2014-12-24 09:33 |显示全部楼层
我想知道你的列数据是用什么分割的? tab还是空格?

论坛徽章:
0
发表于 2014-12-24 09:34 |显示全部楼层
回复 2# goofool

空格啊


   

论坛徽章:
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
发表于 2014-12-24 09:35 |显示全部楼层
回复 1# noiplee

split field with two space and more

$ awk -F'  +' '{print $2}' FILE
SSID
my network
ORANGEnetwork
network222222
applbbbnetwork
applFFFnetwork

论坛徽章:
7
申猴
日期:2014-12-21 13:57:24巳蛇
日期:2014-12-25 22:27:08申猴
日期:2015-01-19 08:07:36辰龙
日期:2015-02-04 11:40:06处女座
日期:2015-02-04 11:40:412015年亚洲杯之卡塔尔
日期:2015-03-06 12:01:322015年亚洲杯之乌兹别克斯坦
日期:2015-03-31 13:43:57
发表于 2014-12-24 10:07 |显示全部楼层
本帖最后由 goofool 于 2014-12-24 10:07 编辑

我觉得你应该用tab(或者其他)分割列。因为SSID这列数据你不能掌握,你就不知道会有几个空格,这样有可能和其他列冲突。

论坛徽章:
0
发表于 2014-12-24 10:11 |显示全部楼层
回复 4# jason680


    Thanks!  I know what your idea.

论坛徽章:
0
发表于 2014-12-24 10:13 |显示全部楼层
回复 5# goofool


    是啊  你知道我的困境了,谢谢!

论坛徽章:
6
羊年新春福章
日期:2015-03-03 17:16:28双子座
日期:2015-03-03 17:16:56巳蛇
日期:2015-03-03 17:17:2415-16赛季CBA联赛之福建
日期:2016-03-11 09:05:00黑曼巴
日期:2016-07-07 16:58:1215-16赛季CBA联赛之吉林
日期:2016-11-14 09:23:07
发表于 2014-12-24 10:22 |显示全部楼层
回复 4# jason680


    两个或两个空格以上,这个方法妙

论坛徽章:
0
发表于 2014-12-24 10:33 |显示全部楼层
感谢各位的思路

后面我准备数据都用/t或者两个/t来分割,这样就可以预防SSID未知的空格或者字符了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

DTCC2020中国数据库技术大会 限时8.5折

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

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

http://dtcc.it168.com


大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP