免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
论坛 程序设计 Shell AWK
最近访问板块 发新帖
查看: 2648 | 回复: 8
打印 上一主题 下一主题

[文本处理] AWK [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-08-21 12:11 |只看该作者 |倒序浏览
求助:
求助各位大神:
现在有这样一个文件, 每四行是一个单元: 如下:
>1
ABDGC
+++++
12345
>2
AHNHB
++72=
12ji2
>3
CCHLJ
*&=-+
658hk
>4
LJKTY
-+=+=
$%^&8
现在我只举了16行4个单元做例子,下边想进行如下操作:如果每个单元的二行, 就是>下边那一行含有C 则把该单元输入到文件1.txt中,不含有C的单元输入到文件2.txt。
谢谢各位!



论坛徽章:
9
2015亚冠之大阪钢巴
日期:2015-06-04 11:47:30丑牛
日期:2015-01-22 15:49:26巳蛇
日期:2015-01-22 10:11:18巨蟹座
日期:2014-11-20 10:55:03天蝎座
日期:2014-11-16 22:10:26处女座
日期:2014-11-16 11:01:10申猴
日期:2014-09-19 11:12:37双鱼座
日期:2014-07-25 10:09:54程序设计版块每日发帖之星
日期:2015-08-24 06:20:00
2 [报告]
发表于 2015-08-21 12:23 |只看该作者
本帖最后由 Buring__ 于 2015-08-21 12:45 编辑
  1. awk -vRS='>' -vFS="\n" '/./{if($2~/C/)print RS$0  >1".txt";else print RS$0>2".txt"}'
复制代码

论坛徽章:
0
3 [报告]
发表于 2015-08-21 12:46 |只看该作者
非常感谢,请问如果要想把每个单元开始的》一起输出,同时单元之前的空行不要不输出,怎么实现呢?谢谢!
回复 2# Buring__


   

论坛徽章:
7
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:57:092015小元宵徽章
日期:2015-03-06 15:58:18程序设计版块每日发帖之星
日期:2015-08-09 06:20:00每日论坛发贴之星
日期:2015-08-09 06:20:00程序设计版块每日发帖之星
日期:2015-08-22 06:20:00程序设计版块每日发帖之星
日期:2015-08-27 06:20:00
4 [报告]
发表于 2015-08-21 13:02 |只看该作者
本帖最后由 tuyajie 于 2015-08-21 13:07 编辑

看错题目了。。重写一个区。。呵呵

论坛徽章:
9
2015亚冠之大阪钢巴
日期:2015-06-04 11:47:30丑牛
日期:2015-01-22 15:49:26巳蛇
日期:2015-01-22 10:11:18巨蟹座
日期:2014-11-20 10:55:03天蝎座
日期:2014-11-16 22:10:26处女座
日期:2014-11-16 11:01:10申猴
日期:2014-09-19 11:12:37双鱼座
日期:2014-07-25 10:09:54程序设计版块每日发帖之星
日期:2015-08-24 06:20:00
5 [报告]
发表于 2015-08-21 13:05 |只看该作者
回复 3# biobaby
  1. awk -vRS='>' -vFS="\n" '/./{if($2~/C/)printf RS$0  >1".txt";else printf RS$0>2".txt"}' urfile
复制代码

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
6 [报告]
发表于 2015-08-21 13:39 |只看该作者
回复 1# biobaby


try
  1. awk '/>/{getline v;f=v~/C/?"1.txt":"2.txt";$0=$0"\n"v}{print>f}' file
复制代码

评分

参与人数 3信誉积分 +30 收起 理由
songyc_2015 + 10 赞一个!
substr函数 + 10 赞一个!
hjfeng1988 + 10 赞一个!

查看全部评分

论坛徽章:
20
卯兔
日期:2015-01-26 22:05:142015亚冠之萨济拖拉机
日期:2015-09-10 15:15:282015亚冠之阿尔希拉尔
日期:2015-09-25 17:37:53程序设计版块每日发帖之星
日期:2015-10-03 06:20:00程序设计版块每日发帖之星
日期:2015-12-09 06:20:00CU十四周年纪念徽章
日期:2015-12-17 09:07:15程序设计版块每日发帖之星
日期:2015-12-25 06:20:34程序设计版块每日发帖之星
日期:2015-12-25 06:20:34程序设计版块每日发帖之星
日期:2015-12-25 06:20:342015亚冠之广州富力
日期:2015-08-27 19:29:56每日论坛发贴之星
日期:2015-08-26 06:20:002015亚冠之阿尔希拉尔
日期:2015-05-18 17:26:27
7 [报告]
发表于 2015-08-22 12:02 |只看该作者
回复 1# biobaby
  1. sed -nr -e '1{h;b};${H;b1};/^>/{:1;x;/^>[0-9]+\nC/{w 1.txt' -e '};//!w 2.txt' -e 'b;};H;' file
复制代码

论坛徽章:
1
2015亚冠之塔什干棉农
日期:2015-09-10 14:27:55
8 [报告]
发表于 2015-08-25 11:33 |只看该作者
看了一上午还是没怎么看明白,能大致讲解一下吗?
多谢了!
回复 6# ly5066113


   

论坛徽章:
1
15-16赛季CBA联赛之江苏
日期:2016-10-26 16:19:04
9 [报告]
发表于 2016-05-13 11:39 |只看该作者
awk 'NR%4==2{if($0~/.*C.*/)print $0>1.txt}NR%4!=2{print $0>2.txt}'  file
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP