免费注册 查看新帖 |

ChinaUnix.net

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

RS、ORS、FS、OFS相关问题 [复制链接]

论坛徽章:
0
发表于 2009-01-14 18:42 |显示全部楼层
file
  1. #
  2. 1
  3. 2
  4. 3
  5. #
  6. 4
  7. 5
  8. #
  9. 6
  10. 7
  11. 8
  12. 9
  13. #
复制代码

如何输出成:
123
45
6789

[ 本帖最后由 ywlscpl 于 2009-1-14 18:44 编辑 ]

论坛徽章:
11
金牛座
日期:2015-03-19 16:56:22数据库技术版块每日发帖之星
日期:2016-08-02 06:20:00数据库技术版块每日发帖之星
日期:2016-04-24 06:20:00数据库技术版块每日发帖之星
日期:2016-04-13 06:20:00IT运维版块每日发帖之星
日期:2016-04-13 06:20:00数据库技术版块每日发帖之星
日期:2016-02-03 06:20:00数据库技术版块每日发帖之星
日期:2015-08-06 06:20:00季节之章:春
日期:2015-03-27 15:54:57羊年新春福章
日期:2015-03-27 15:54:37戌狗
日期:2015-03-19 16:56:41数据库技术版块每日发帖之星
日期:2016-08-18 06:20:00
发表于 2009-01-14 18:59 |显示全部楼层
错鸟....

[ 本帖最后由 liaosnet 于 2009-1-14 19:04 编辑 ]

论坛徽章:
0
发表于 2009-01-14 19:02 |显示全部楼层
感觉很奇怪
  1. # awk 'BEGIN{RS="#\n";ORS="\n";FS="\n";OFS=","}NR!=1{print $0}' file

  2. 1
  3. 2
  4. 3


  5. 4
  6. 5


  7. 6
  8. 7
  9. 8
  10. 9



  11. # awk 'BEGIN{RS="#\n";ORS="\n";FS="\n";OFS=","}NR!=1{print $1,$2,$3,$4,$5}' f>
  12. ,1,2,3,
  13. ,4,5,,
  14. ,6,7,8,9
  15. ,,,,
复制代码


前面那个OFS=","为什么没起作用呢?

[ 本帖最后由 ywlscpl 于 2009-1-14 19:10 编辑 ]

论坛徽章:
0
发表于 2009-01-14 19:04 |显示全部楼层
原帖由 liaosnet 于 2009-1-14 18:59 发表
awk 'BEGIN{RS=FS="#"}' file

  1. # awk 'BEGIN{RS=FS="#"}' file
  2. #
复制代码

论坛徽章:
11
金牛座
日期:2015-03-19 16:56:22数据库技术版块每日发帖之星
日期:2016-08-02 06:20:00数据库技术版块每日发帖之星
日期:2016-04-24 06:20:00数据库技术版块每日发帖之星
日期:2016-04-13 06:20:00IT运维版块每日发帖之星
日期:2016-04-13 06:20:00数据库技术版块每日发帖之星
日期:2016-02-03 06:20:00数据库技术版块每日发帖之星
日期:2015-08-06 06:20:00季节之章:春
日期:2015-03-27 15:54:57羊年新春福章
日期:2015-03-27 15:54:37戌狗
日期:2015-03-19 16:56:41数据库技术版块每日发帖之星
日期:2016-08-18 06:20:00
发表于 2009-01-14 19:07 |显示全部楼层

回复 #4 ywlscpl 的帖子

错鸟......没经大脑...

论坛徽章:
3
戌狗
日期:2014-09-10 17:07:162015年辞旧岁徽章
日期:2015-03-03 16:54:15wusuopu
日期:2016-06-17 17:43:45
发表于 2009-01-14 19:16 |显示全部楼层
有点长
  1. awk -v RS=# 'NF{for(i=1;i<=NF;i++)if($i) printf $i;print ""}' urfile
复制代码

论坛徽章:
0
发表于 2009-01-14 19:18 |显示全部楼层
andy能解答一下3楼中的问题吗?感到很疑惑

论坛徽章:
0
发表于 2009-01-14 19:27 |显示全部楼层
  1. # awk -v RS=# 'NF{for(i=1;i<=NF;i++)if($i) printf $i;print ""}' file
  2. 123
  3. 45
  4. 6789
  5. #
复制代码

但如果想自定义FS又该如何呢,比如输出为
1,2,3
4,5
6,7,8,9

这样的效果并不好
  1. # awk -v RS=#  'NF{for(i=1;i<=NF;i++)if($i) printf $i",";print ""}'>
  2. 1,2,3,
  3. 4,5,
  4. 6,7,8,9,
复制代码

论坛徽章:
0
发表于 2009-01-14 19:31 |显示全部楼层
awk 'BEGIN{FS="\n";RS="#\n";ORS="\n";}{for(i=1;i<=NF;i++){printf("%s ",$i)}printf("\n");}' data.txt

sed&awk书里有关于这方面的描述,如果定义了 OFS和ORS的话 一定要变一下,不然的话OFS和ORS不会起作用,原话我忘记了,你翻下书就明白了

论坛徽章:
3
戌狗
日期:2014-09-10 17:07:162015年辞旧岁徽章
日期:2015-03-03 16:54:15wusuopu
日期:2016-06-17 17:43:45
发表于 2009-01-14 19:38 |显示全部楼层
原帖由 ywlscpl 于 2009-1-14 19:27 发表
# awk -v RS=# 'NF{for(i=1;i
  1. awk -v RS=# 'NF{for(i=1;i<=NF;i++)if($i) printf (i>1?",":"")$i;print ""}'
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

数据风云,十年变迁
DTCC 第十届中国数据库技术大会已启航!

2019年5月8日~5月10日,由IT168旗下ITPUB企业社区平台主办的第十届中国数据库技术大会(DTCC2019),将在北京隆重召开。大会将邀请百余位行业专家,就热点技术话题进行分享,是广大数据领域从业人士的又一次年度盛会和交流平台。与SACC2018类似,本届大会将采用“3+2”模式:3天传统技术演讲+2天深度主题培训。大会不仅提供超100场的主题演讲,还会提供连续2天的深度课程培训,深化数据领域的项目落地实践方案。
DTCC2019,一场值得期待的数据技术盛会,殷切地希望您报名参与!

活动入口>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP