免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2237 | 回复: 7
打印 上一主题 下一主题

格式化输入 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-06-10 12:12 |只看该作者 |倒序浏览
某文件如下输入格式:

USERNAME           CLRID              MDN        LOGTIME       LOGTYPE   RESULT   ERRORID     REMARK
import2                                                  1243926419         1           2           110         Can not get MNID!
import2                   1                  2          1243926419         1           2           110         Can not get MNID!

其中以空格分割,而非tab,请问对于其中没有值的字段,可否取得,比如第一行,希望$2="",$3="",而非$2="1243926419"(实际应该是$4,但由于FS=" ",造成被识别为分隔符)。

多谢~~~

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
2 [报告]
发表于 2009-06-10 12:13 |只看该作者

回复 #1 thinshootout 的帖子

FS='[ ]'

论坛徽章:
0
3 [报告]
发表于 2009-06-10 12:34 |只看该作者

回复 #2 blackold 的帖子

这样的话,连$3 - $8也都变成了空……

论坛徽章:
0
4 [报告]
发表于 2009-06-10 12:37 |只看该作者

回复 #2 blackold 的帖子

现在需要:$1="import2",$2="",$3="",$4="1243926419",$5="1",$6="2",$7="110",$8="Can not get MNID!"

论坛徽章:
0
5 [报告]
发表于 2009-06-10 12:41 |只看该作者
你这是定长格式?

论坛徽章:
0
6 [报告]
发表于 2009-06-10 12:45 |只看该作者
先处理一下,将连续空格换其它字符

论坛徽章:
0
7 [报告]
发表于 2009-06-10 12:51 |只看该作者

回复 #1 thinshootout 的帖子

awk '$1=$1' urf | sed 's/\(import2 \)\([0-9][0-9]\+\)/\1    \2/'

论坛徽章:
0
8 [报告]
发表于 2009-06-10 18:42 |只看该作者
单单针对你这个例子:

  1. awk --posix -F" {3,20}" '{for(i=1;i<=NF;i++) printf $i" # ";print ""}' URFILE
复制代码


其中,因为FS要用到正则,加上了--posix参数;3和20是估测的,3为最小的间隔空格数,20为最大的间隔空格数。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP