LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 738|回复: 5

取一个文本文件中每一行的头几个字符

[复制链接]
发表于 2004-5-19 16:35:12 | 显示全部楼层 |阅读模式
如果我要取一个文本文件中每一行的头几个字符用什么命令?
例如:
test.txt
123s68876553230
15s664211654512
156f84321321564

要求没行保留5个字符!
test.do
123s6
15s66
156f8
发表于 2004-5-19 16:57:21 | 显示全部楼层
方法很多,;)
  1. cat file|cut -c1-5
复制代码
发表于 2004-5-19 18:16:42 | 显示全部楼层
  1. $ sed -e "s/^\(.....\).*/\1/" /your/file
  2. $ sed -e "s/^\(.\{5\}\).*/\1/" /your/file
复制代码
发表于 2004-5-19 18:19:29 | 显示全部楼层

管道确实是好东西.^_^

也可以用sed

sed -e 's/^\(.\{1,5\}\).*/\1/' test.txt

若是有空行或少于5个字符的行,则保留该行.
发表于 2004-5-19 18:29:55 | 显示全部楼层

回复: 管道确实是好东西.^_^

最初由 retypedef 发表
也可以用sed

sed -e 's/^\(.\{1,5\}\).*/\1/' test.txt

若是有空行或少于5个字符的行,则保留该行.

呵呵,那就多了,像awk:
  1. awk '{print substr($0,1,5)}'
复制代码
发表于 2004-5-19 22:27:11 | 显示全部楼层

你说的对,赞同!我说管道好用,没别的意思,而是觉得pipe, redirection还有那些小巧的tools

赫赫,可惜awk我不懂喔.^_^
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表