免费注册 查看新帖 |

Chinaunix

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

用shell如何提取一个文件的某一列? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-05-22 12:48 |只看该作者 |倒序浏览
这个文件有20000行,每一行的列数不等,每行中间有不定数目的空格
大致是这样的:
111111000000123  24564 5689 4568 56541  00000000
110125456558863  29862 1235 4896 12368  11111
145698788989999  56897 1589 2365 98765  0255888889999999666
那我想把每一行的第19列(包含空格在内),从这个文件中删除,摘取到另外一个文件中,,应该怎么才能实现?谢谢

论坛徽章:
0
2 [报告]
发表于 2008-05-22 12:53 |只看该作者
原帖由 miffy米菲 于 2008-5-22 12:48 发表
这个文件有20000行,每一行的列数不等,每行中间有不定数目的空格
大致是这样的:
111111000000123  24564 5689 4568 56541  00000000
110125456558863  29862 1235 4896 12368  11111
145698788989999  56 ...

  1. ( head -n 18 filename ; tail -n +20 filename ) > newfilename
复制代码


--

论坛徽章:
0
3 [报告]
发表于 2008-05-22 14:10 |只看该作者

回复 #1 miffy米菲 的帖子

man awk 试一下

论坛徽章:
0
4 [报告]
发表于 2008-05-22 16:48 |只看该作者
原帖由 kenduest 于 2008-5-22 12:53 发表


( head -n 18 filename ; tail -n +20 filename ) > newfilename

--


老大理解错题意了,是提取第十九列。这个应该用 cut 来完成。


  1. cut -d' ' -f 19 FILE
复制代码

论坛徽章:
0
5 [报告]
发表于 2008-05-22 17:49 |只看该作者

回复 #4 swordfish.cn 的帖子

cut只能按固定的单字符分隔或按位置分隔吧,如果由不定的空格分的列(如ls -l的结果)它是没办法的。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
6 [报告]
发表于 2008-05-22 20:13 |只看该作者
原帖由 Cyberman.Wu 于 2008-5-22 17:49 发表
cut只能按固定的单字符分隔或按位置分隔吧,如果由不定的空格分的列(如ls -l的结果)它是没办法的。

用 awk 撒

论坛徽章:
0
7 [报告]
发表于 2008-05-22 20:44 |只看该作者
原帖由 Cyberman.Wu 于 2008-5-22 17:49 发表
cut只能按固定的单字符分隔或按位置分隔吧,如果由不定的空格分的列(如ls -l的结果)它是没办法的。


是的,确实有这个不足。
那还是用 awk 和 sed 这样的工具做吧。

论坛徽章:
0
8 [报告]
发表于 2008-05-23 02:30 |只看该作者
原帖由 swordfish.cn 于 2008-5-22 20:44 发表
是的,确实有这个不足。
那还是用 awk 和 sed 这样的工具做吧。


我果然會錯意。那改一下:

[code]awk ' { print $19 }'

--
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP