免费注册 查看新帖 |

Chinaunix

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

[求助]把采集数据格式转换成文本文件 [复制链接]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-06-21 18:55 |只看该作者 |倒序浏览
有软件导出的数据文本(数据采集记录分类.txt),里面有很多数据格式如下示例文档,文档中毎三行为一个数据记录,第一行是文件夹名称(条件06-05数据采集),第二行与第三行是采集文本名称(39、25),我需要把它们按毎三行转换成一个文本文件,如下是样本示例文件,谢谢大家!


数据采集记录分类.txt  (样本文件只给岀了4条采集记录)

条件06-05数据采集
39
25
条件06-sh10数据采集
17
11
条件06-sh11-21-数据采集
17
09
条件06-改良类-01数据采集
509
487
·
·
·

想把它转换成下面的样式;也就是毎个记录转成一个独立的文档

条件06-05数据采集.txt
del D:\条件06-05数据采集\39.txt
del D:\条件06-05数据采集\38.txt
del D:\条件06-05数据采集\37.txt
del D:\条件06-05数据采集\36.txt
del D:\条件06-05数据采集\35.txt
del D:\条件06-05数据采集\34.txt
del D:\条件06-05数据采集\33.txt
del D:\条件06-05数据采集\32.txt
del D:\条件06-05数据采集\31.txt
del D:\条件06-05数据采集\30.txt
del D:\条件06-05数据采集\29.txt
del D:\条件06-05数据采集\28.txt
del D:\条件06-05数据采集\27.txt
del D:\条件06-05数据采集\26.txt
del D:\条件06-05数据采集\25.txt

条件06-sh10数据采集.txt
del D:\条件06-sh10数据采集\17.txt
del D:\条件06-sh10数据采集\16.txt
del D:\条件06-sh10数据采集\15.txt
del D:\条件06-sh10数据采集\14.txt
del D:\条件06-sh10数据采集\13.txt
del D:\条件06-sh10数据采集\12.txt
del D:\条件06-sh10数据采集\11.txt

条件06-sh11-21-数据采集.txt
del D:\条件06-sh11-21-数据采集\17.txt
del D:\条件06-sh11-21-数据采集\16.txt
del D:\条件06-sh11-21-数据采集\15.txt
del D:\条件06-sh11-21-数据采集\14.txt
del D:\条件06-sh11-21-数据采集\13.txt
del D:\条件06-sh11-21-数据采集\12.txt
del D:\条件06-sh11-21-数据采集\11.txt
del D:\条件06-sh11-21-数据采集\10.txt
del D:\条件06-sh11-21-数据采集\09.txt

条件06-改良类-01数据采集.txt
del D:\条件06-改良类-01数据采集\509.txt
del D:\条件06-改良类-01数据采集\508.txt
del D:\条件06-改良类-01数据采集\507.txt
del D:\条件06-改良类-01数据采集\506.txt
del D:\条件06-改良类-01数据采集\505.txt
del D:\条件06-改良类-01数据采集\504.txt
del D:\条件06-改良类-01数据采集\503.txt
del D:\条件06-改良类-01数据采集\502.txt
del D:\条件06-改良类-01数据采集\501.txt
del D:\条件06-改良类-01数据采集\500.txt
del D:\条件06-改良类-01数据采集\499.txt
del D:\条件06-改良类-01数据采集\498.txt
del D:\条件06-改良类-01数据采集\497.txt
del D:\条件06-改良类-01数据采集\496.txt
del D:\条件06-改良类-01数据采集\495.txt
del D:\条件06-改良类-01数据采集\494.txt
del D:\条件06-改良类-01数据采集\493.txt
del D:\条件06-改良类-01数据采集\492.txt
del D:\条件06-改良类-01数据采集\491.txt
del D:\条件06-改良类-01数据采集\490.txt
del D:\条件06-改良类-01数据采集\489.txt
del D:\条件06-改良类-01数据采集\488.txt
del D:\条件06-改良类-01数据采集\487.txt

我现在转换是用excel下手工转,太多太麻烦还出差,想请大家看看能否用perl解决,谢谢!

论坛徽章:
0
2 [报告]
发表于 2015-06-22 14:09 |只看该作者
以下脚本希望可以。
  1. #!/usr/bin/perl
  2. use strict;
  3. use warnings;

  4. my ($i, $j, $k, $l);
  5. while (<>) {
  6.         chomp;
  7.         if (! $i) {
  8.                 ($j = $_) =~ s/(.+)/$1.txt/;
  9.                 print "\n$j\n";
  10.                 $i = 1;
  11.         } else {
  12.                 $k = $_;
  13.                 $l = <>;
  14.                 chomp $l;
  15.                 for (-$k..-$l) {
  16.                         print "del D:\\$j\\", -$_, ".txt\n";
  17.                         $i = 0;
  18.                 }
  19.         }
  20. }
复制代码

论坛徽章:
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
3 [报告]
发表于 2015-06-23 00:57 |只看该作者
本帖最后由 songyc_2015 于 2015-06-23 01:03 编辑

回复 1# hkldd
  1. #!/usr/bin/env perl
  2. use strict;
  3. use warnings;

  4. my ($line, $name, $start, $end);
  5. while (<>)
  6. {
  7.         ++$line;
  8.         chomp;
  9.         $name = $_.".txt" if ($line % 3 == 1);
  10.         $end = $_ if ($line % 3 == 2);
  11.         $start = $_ if ($line % 3 == 0);

  12.         if ($line % 3 == 0)
  13.         {
  14.                 open(FH, ">$name") or die("open file[$name]error:$!\n");
  15.                 $name =~ s/.txt$//;
  16.                 for (my $i=$end; $i>=$start; $i--)
  17.                 {
  18.                         printf(FH "del D:\\%s\\%02d.txt\n", $name, $i);
  19.                 }
  20.                 close FH;
  21.         }
  22. }
复制代码

论坛徽章:
307
程序设计版块每周发帖之星
日期:2016-04-08 00:41:33操作系统版块每日发帖之星
日期:2015-09-02 06:20:00每日论坛发贴之星
日期:2015-09-02 06:20:00程序设计版块每日发帖之星
日期:2015-09-04 06:20:00每日论坛发贴之星
日期:2015-09-04 06:20:00每周论坛发贴之星
日期:2015-09-06 22:22:00程序设计版块每日发帖之星
日期:2015-09-09 06:20:00程序设计版块每日发帖之星
日期:2015-09-19 06:20:00程序设计版块每日发帖之星
日期:2015-09-20 06:20:00每日论坛发贴之星
日期:2015-09-20 06:20:00程序设计版块每日发帖之星
日期:2015-09-22 06:20:00程序设计版块每日发帖之星
日期:2015-09-24 06:20:00
4 [报告]
发表于 2016-09-15 10:10 |只看该作者
  1. perl -nle '{if(/\A\D/){push(@{$a[++$n]},$_);next}push(@{$a[$n]},$_)}END{foreach $e (splice(@a,1)){print("del D:\\$e->[0]\\$e->[$_]\.txt") for(1..$#$e)}}' f
复制代码

del D:\条件06-05数据采集\39.txt
del D:\条件06-05数据采集\25.txt
del D:\条件06-sh10数据采集\17.txt
del D:\条件06-sh10数据采集\11.txt
del D:\条件06-sh11-21-数据采集\17.txt
del D:\条件06-sh11-21-数据采集\09.txt
del D:\条件06-改良类-01数据采集\509.txt
del D:\条件06-改良类-01数据采集\487.txt

论坛徽章:
28
15-16赛季CBA联赛之八一
日期:2016-02-22 19:10:4215-16赛季CBA联赛之深圳
日期:2016-12-01 10:34:0415-16赛季CBA联赛之新疆
日期:2016-12-07 10:24:2915-16赛季CBA联赛之同曦
日期:2016-12-15 12:06:43CU十四周年纪念徽章
日期:2016-12-18 13:03:4415-16赛季CBA联赛之吉林
日期:2017-01-03 15:52:2515-16赛季CBA联赛之辽宁
日期:2017-01-04 14:58:2415-16赛季CBA联赛之辽宁
日期:2017-01-15 09:42:512016科比退役纪念章
日期:2017-02-06 17:21:50黑曼巴
日期:2017-02-10 15:46:1215-16赛季CBA联赛之上海
日期:2017-03-18 10:14:5415-16赛季CBA联赛之青岛
日期:2017-03-18 22:00:44
5 [报告]
发表于 2016-09-26 11:20 |只看该作者

  1. awk '/-/{s=$0;print (!f++?"":RS) s".txt";getline;a=$1;getline;b=$1;for(i=a;i>=b;i--)print "del D:\\"s"\\"i".txt"}' file
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP