免费注册 查看新帖 |

Chinaunix

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

[文本处理] 切割文件 求教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-10-10 23:24 |只看该作者 |倒序浏览
有一个文件,我想把它切成多份。把多个以begin 开头的数据块切割出来
内容
begin  1234
122344
223233
2233
begin  24334
44
sdfsd
456dfg
sdf
begin sdfd3445
dsafwf
sdf4tr234
3fdf

输出结果为
begin  1234
122344
223233
2233
-----------------------------
begin  24334
44
sdfsd
456dfg
sdf
-------------
begin sdfd3445
dsafwf
sdf4tr234
3fdf

论坛徽章:
0
2 [报告]
发表于 2014-10-10 23:27 |只看该作者
补充一下 ,能不能输出结果为第几行到第几行 。
例如刚才就是1到4,5到9,10到13

论坛徽章:
8
戌狗
日期:2014-09-26 16:39:44水瓶座
日期:2014-10-10 02:06:57金牛座
日期:2014-10-11 23:04:042015亚冠之首尔
日期:2015-06-23 15:37:0015-16赛季CBA联赛之天津
日期:2016-01-22 18:58:2915-16赛季CBA联赛之佛山
日期:2016-05-31 19:18:0815-16赛季CBA联赛之同曦
日期:2016-08-10 16:26:3315-16赛季CBA联赛之辽宁
日期:2018-01-10 11:47:40
3 [报告]
发表于 2014-10-10 23:50 |只看该作者
  1. # awk  '/^begin/{if(NR>1){print "-------"};print NR,$0;next}{print NR,$0;}'  15.txt
  2. 1 begin  1234
  3. 2 122344
  4. 3 223233
  5. 4 2233
  6. -------
  7. 5 begin  24334
  8. 6 44
  9. 7 sdfsd
  10. 8 456dfg
  11. 9 sdf
  12. -------
  13. 10 begin sdfd3445
  14. 11 dsafwf
  15. 12 sdf4tr234
  16. 13 3fdf
复制代码

论坛徽章:
3
丑牛
日期:2014-09-13 18:19:22摩羯座
日期:2014-10-10 17:43:02水瓶座
日期:2014-10-16 01:00:22
4 [报告]
发表于 2014-10-10 23:54 |只看该作者
学生党:飘过~无聊用Python试试

  1. $ cat yhsafe.py
  2. #!/usr/bin/env python
  3. # -*- coding:utf-8 -*-
  4. "just for fun"

  5. import re
  6. import sys
  7. import fileinput
  8. for x in re.findall(r'^b[^b]*',open(sys.argv[1]).read(),re.M):
  9.         print x.split('\n')[0]
  10.         print '\n'.join(x.split('\n')[1:]),
  11.         print '-'*20

复制代码
测试:
$ ./yhsafe.py yhsafe.txt
begin  1234
122344
223233
2233
--------------------
begin  24334
44
sdfsd
456dfg
sdf
--------------------
begin sdfd3445
dsafwf
sdf4tr234
3fdf

--------------------

begin sdfd3445
dsafwf
sdf4tr234
3fdf

论坛徽章:
14
15-16赛季CBA联赛之辽宁
日期:2019-06-16 15:47:3515-16赛季CBA联赛之广夏
日期:2016-08-13 21:24:352015亚冠之武里南联
日期:2015-07-07 17:37:372015亚冠之萨济拖拉机
日期:2015-07-06 17:07:482015亚冠之全北现代
日期:2015-06-04 13:54:272015亚冠之城南
日期:2015-05-21 15:43:212015年亚洲杯之伊朗
日期:2015-04-25 18:20:362015年亚洲杯之伊朗
日期:2015-04-20 16:06:052015年亚洲杯之科威特
日期:2015-03-07 12:51:26丑牛
日期:2014-12-30 10:26:38申猴
日期:2014-09-28 22:40:18金牛座
日期:2014-09-13 21:12:22
5 [报告]
发表于 2014-10-11 02:26 |只看该作者
  1. awk  -vRS='begin' 'NR>2{print RS,s"--------------------"}{s=$0}END{print s}'

  2. sed -rn '{1h;1!H;${g;s/\nbegin/\n-------------\nbegin/gp}}'  1
复制代码

论坛徽章:
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 [报告]
发表于 2014-10-11 08:24 |只看该作者
回复 1# skytalemcc


try:
  1. awk '/begin/{if(NR>1)print "----- "n"-"NR-1" -----";n=NR}1;END{print "----- "n"-"NR" -----"}' file
复制代码

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
7 [报告]
发表于 2014-10-11 09:01 |只看该作者
  1. sed ':1;n;/^begin/s/^/------\n/;b1'
复制代码

论坛徽章:
30
申猴
日期:2014-04-10 09:43:532015年亚洲杯纪念徽章
日期:2015-03-20 14:40:232015亚冠之阿尔纳斯尔
日期:2015-06-02 18:59:042015亚冠之阿尔希拉尔
日期:2015-06-30 15:22:572015亚冠之大阪钢巴
日期:2015-07-20 10:44:332015亚冠之阿尔纳斯尔
日期:2015-10-28 14:57:5215-16赛季CBA联赛之新疆
日期:2015-12-25 10:18:45黑曼巴
日期:2016-06-26 21:39:5315-16赛季CBA联赛之山西
日期:2016-07-25 21:54:2715-16赛季CBA联赛之北京
日期:2016-10-27 12:07:2315-16赛季CBA联赛之八一
日期:2017-07-07 16:39:0915-16赛季CBA联赛之吉林
日期:2017-09-04 12:14:43
8 [报告]
发表于 2014-10-11 09:34 |只看该作者
回复 1# skytalemcc
awk  -F "\n" -v RS="begin" -v ORS="-------\n"  'NR>1{if(!s) {s=1;print "begin"$0"------" s "-" NF-1;s=NF}
else {print "begin" $0 "------" s "-" NF-2+s;s+=NF-1} }' FILE


   

论坛徽章:
9
射手座
日期:2014-07-29 13:05:07双子座
日期:2015-01-11 17:01:522015年亚洲杯之朝鲜
日期:2015-02-01 16:14:282015亚冠之阿尔艾因
日期:2015-06-04 17:54:40数据库技术版块每日发帖之星
日期:2015-08-02 06:20:00数据库技术版块每日发帖之星
日期:2015-10-28 06:20:00数据库技术版块每日发帖之星
日期:2015-11-26 06:20:0015-16赛季CBA联赛之天津
日期:2016-06-20 17:09:2015-16赛季CBA联赛之青岛
日期:2017-02-26 15:54:19
9 [报告]
发表于 2014-10-11 09:52 |只看该作者
  1. sed '2,${/begin/{x;p;x}}' cc01.txt |sed 's/^$/-----------/' -r
复制代码

论坛徽章:
9
射手座
日期:2014-07-29 13:05:07双子座
日期:2015-01-11 17:01:522015年亚洲杯之朝鲜
日期:2015-02-01 16:14:282015亚冠之阿尔艾因
日期:2015-06-04 17:54:40数据库技术版块每日发帖之星
日期:2015-08-02 06:20:00数据库技术版块每日发帖之星
日期:2015-10-28 06:20:00数据库技术版块每日发帖之星
日期:2015-11-26 06:20:0015-16赛季CBA联赛之天津
日期:2016-06-20 17:09:2015-16赛季CBA联赛之青岛
日期:2017-02-26 15:54:19
10 [报告]
发表于 2014-10-11 10:11 |只看该作者
回复 7# yestreenstars

sed '2,${/begin/s/^/----------\n/}'   借鉴您的,不循环如何
   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP