免费注册 查看新帖 |

Chinaunix

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

[文本处理] 请教如何文件名保存为新文件列名 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-09-20 03:09 |只看该作者 |倒序浏览
有200个txt文件,提取每个文件的第二列,并把所有200个文件的第二列合成一个新文件。
我想实现这样:

比如3个txt文件: 1.txt, 2.txt, 3.txt。。。

文件1.txt内容为:
site1     54
site2     89
site3     45

文件2.txt内容为:
site1     100
site2     97
site3     46

文件3.txt内容为:
site1     120
site2     66
site3     55

。。。

最后output.txt 文件在第一行加一行名称,名称显示这一列是从哪个文件的第二列来的,最后文件如下:
1.txt      2.txt     3.txt    。。。
54         100       120     。。。
89         97         66       。。。
45         46         55       。。。

再次感谢!

论坛徽章:
13
双鱼座
日期:2013-10-23 09:30:05数据库技术版块每日发帖之星
日期:2016-04-20 06:20:00程序设计版块每日发帖之星
日期:2016-03-09 06:20:002015亚冠之塔什干火车头
日期:2015-11-02 10:07:452015亚冠之德黑兰石油
日期:2015-08-30 10:07:07数据库技术版块每日发帖之星
日期:2015-08-28 06:20:00数据库技术版块每日发帖之星
日期:2015-08-05 06:20:002015年迎新春徽章
日期:2015-03-04 09:57:09辰龙
日期:2014-12-03 14:45:52酉鸡
日期:2014-07-23 09:46:23亥猪
日期:2014-03-13 08:46:22金牛座
日期:2014-02-11 09:36:21
2 [报告]
发表于 2013-09-20 09:23 |只看该作者
awk '{if(FNR==1){a[0]=a[0]?a[0]"\t"FILENAME:FILENAME;}a[FNR]=a[FNR]?a[FNR]"\t"$22}END{for(i in a){print a[i]}}' 1.txt  2.txt 3.txt

论坛徽章:
0
3 [报告]
发表于 2013-09-20 20:56 |只看该作者
如果是200个txt 文件呢,一个一个输文件名么?


回复 2# bikong0411


   

论坛徽章:
0
4 [报告]
发表于 2013-09-20 21:16 |只看该作者
或者200个文件,每个文件只有一列,用paste把他们都何在一起。

怎么加对应的表头呢?

谢谢!

bikong0411 发表于 2013-09-20 09:23
awk '{if(FNR==1){a[0]=a[0]?a[0]"\t"FILENAME:FILENAME;}a[FNR]=a[FNR]?a[FNR]"\t"$22}END{for(i in a){ ...

论坛徽章:
50
15-16赛季CBA联赛之广夏
日期:2018-11-05 09:42:462015年亚冠纪念徽章
日期:2015-07-23 11:58:122015亚冠之广州富力
日期:2015-07-07 08:26:172015亚冠之塔什干棉农
日期:2015-06-29 09:08:072015年亚洲杯之伊朗
日期:2015-03-08 20:51:012015年迎新春徽章
日期:2015-03-04 09:58:11未羊
日期:2014-10-16 22:41:47处女座
日期:2014-10-16 15:33:33酉鸡
日期:2014-03-13 12:54:10巳蛇
日期:2014-03-10 14:39:052015亚冠之德黑兰石油
日期:2015-07-29 12:46:372015亚冠之德黑兰石油
日期:2015-08-07 12:54:11
5 [报告]
发表于 2013-09-20 22:14 |只看该作者
本帖最后由 WilliBhamlll 于 2013-09-20 22:18 编辑

[quote]qcshare 发表于 2013-09-20 20:56
如果是200个txt 文件呢,一个一个输文件名么?

想错了

论坛徽章:
10
天蝎座
日期:2013-09-22 22:32:23程序设计版块每日发帖之星
日期:2016-08-07 06:20:00lufei
日期:2016-06-17 17:38:40程序设计版块每日发帖之星
日期:2016-06-12 06:20:002016科比退役纪念章
日期:2016-05-31 15:47:20CU十四周年纪念徽章
日期:2016-05-27 12:24:562015年亚洲杯之阿曼
日期:2015-05-03 21:01:352015年辞旧岁徽章
日期:2015-03-03 16:54:15天蝎座
日期:2013-10-20 21:05:24程序设计版块每日发帖之星
日期:2016-08-11 06:20:00
6 [报告]
发表于 2013-09-20 22:57 |只看该作者
回复 4# qcshare


    只有一列就这样"

  1. echo *.txt>/udir/all.txt
  2. paste *.txt>>/udir/all.txt

复制代码

论坛徽章:
4
白羊座
日期:2013-09-17 21:59:30技术图书徽章
日期:2013-10-12 22:16:03白羊座
日期:2013-10-14 11:01:40双子座
日期:2013-12-17 18:26:39
7 [报告]
发表于 2013-09-20 23:22 |只看该作者
回复 4# qcshare
试试这个
  1. ls *.txt | xargs echo | tee dist_file | xargs paste | awk  -vORS="\t" '{i=2;while(i<NF){print $i;i+=2}printf "%s\n",$NF}' > tmp_file;cat tmp_file >> dist_file;rm tmp_file
复制代码

论坛徽章:
0
8 [报告]
发表于 2013-09-21 00:47 |只看该作者
嗯,谢谢啦~

回复 6# liion631818


   

论坛徽章:
0
9 [报告]
发表于 2013-09-21 00:47 |只看该作者
非常感谢~
回复 7# 井蛙夏虫


   

论坛徽章:
13
双鱼座
日期:2013-10-23 09:30:05数据库技术版块每日发帖之星
日期:2016-04-20 06:20:00程序设计版块每日发帖之星
日期:2016-03-09 06:20:002015亚冠之塔什干火车头
日期:2015-11-02 10:07:452015亚冠之德黑兰石油
日期:2015-08-30 10:07:07数据库技术版块每日发帖之星
日期:2015-08-28 06:20:00数据库技术版块每日发帖之星
日期:2015-08-05 06:20:002015年迎新春徽章
日期:2015-03-04 09:57:09辰龙
日期:2014-12-03 14:45:52酉鸡
日期:2014-07-23 09:46:23亥猪
日期:2014-03-13 08:46:22金牛座
日期:2014-02-11 09:36:21
10 [报告]
发表于 2013-09-21 08:55 |只看该作者
回复 3# qcshare


    awk也支持*.txt啊
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP