Chinaunix首页 | 论坛 | 博客
  • 博客访问: 139827
  • 博文数量: 17
  • 博客积分: 330
  • 博客等级: 一等列兵
  • 技术积分: 135
  • 用 户 组: 普通用户
  • 注册时间: 2012-01-03 14:32
文章分类

全部博文(17)

文章存档

2015年(1)

2013年(2)

2012年(14)

分类: LINUX

2012-05-09 10:54:16

 第15章 文本过滤器

head [ -n lines ] files 例如: head -5 files
用以显示文件的前n行,但有些系统会少显示一行

ls -lut /home/****/putd | head -5
将文件夹 putd 下的文件按访问频繁次数排列,然后显示前5行

tail [ -n lines ] files 
用以显示文件的后n 行

ls -lt /home/***/putd | tail -5
将文件夹 putd 下的文件按最后修改时间排序(-t),然后显示最后5行
然而这样是显示最旧的五行,可以,将其逆序排列(-r),或者使用head

ls -ltr /home/***/putd | tail -5

tail -f file 
选项 -f 可以使得当程序在写一个文件是,读取文件的最后几行,如运行文件的日志,
但是该命令使得机器的负载增高,不太推荐。

tail -f /var/log/httpd/access_log
查看指向系统的HTTP的请求。


使用 grep
用于查找一个或多个文件中包含某一个词或者短语的行
grep word filename_1 filename_2.....

grep默认区分大小写。
grep -i word filename_1 filename_2 ...

查找不包含特定内容somebody的,即取其补集
grep -v somebody  filename

增加行号
grep -n .....

只显示文件名

grep delete /home/****
但是此种方法,却会显示重复的内容
grep -l delete /home/***
仅列出表单


怎样数文件中的单词----比如文件  ch15.doc

tr命令(transliterate的缩写)把一组字符转化为第二组字符
tr    'set1'    'set2'

sort 命令把一个输入文件中的行进行排序

uniq命令(unique的缩写)打印一个文件中所以的唯一一行

第一步---除掉文中所有的标点和分隔符:
有些单词用标点符号分隔
tr '! ? " : ; \[ \] { } ( ) , . '   ' ' < ch15.doc
有些单词用制表符(\t),回车(\n)分隔单词,
所以将 \t \n也添加至上面的命令
tr '! ? " : ; \[ \] { } ( ) , . \t \n '   ' ' < ch15.doc

第二步---将文中的大写字符替换成小写字符
tr '! ? " : ; \[ \] { } ( ) , . \t \n '   ' ' < ch15.doc | tr 'A-Z' 'a-z'
该命令的前一部分输入是ch15.doc,后一部分的输入是前一部分的输出

第三步---压缩文中的空格
将多个重复字符压缩为一个
tr -s  'set1' ,例如,echo "feed me" | tr -s 'e'
输出 
fed me
推广一下,可以同时压缩多个字符
tr -s 'lm' 可以将输入内容中的字母 l , m同时压缩
再在第二步中的命令后加上压缩空格的命令,则形成如下命令
tr '! ? " : ; \[ \] { } ( ) , . \t \n '   ' ' < ch15.doc | tr 'A-Z' 'a-z' | tr -s ' '

第四步--对文件中的行进行排序
为了对文件中的行进行排序,需要将所有的单词独占一行,那么需要增加命令
tr ' ' '\n'即将空格替换为换行符,继而对问件排序:
tr '! ? " : ; \[ \] { } ( ) , . \t \n '   ' ' < ch15.doc | tr 'A-Z' 'a-z' | tr -s ' ' | tr ' ' '\n' | sort 

第五步--保留唯一一行同时排序数字
uniq命令只保留重复行中的一行,  -c 选项可以打印一个字符出现的次数
tr '! ? " : ; \[ \] { } ( ) , . \t \n '   ' ' < ch15.doc | tr 'A-Z' 'a-z' | tr -s ' ' | tr ' ' '\n' | sort | uniq -c
同时为了将结果按单词次数由多至少排列下来,则序再排序。另外,输出最多的10个
tr '! ? " : ; \[ \] { } ( ) , . \t \n '   ' ' < ch15.doc | tr 'A-Z' 'a-z' | tr -s ' ' | tr ' ' '\n' | sort | uniq -c | sort -rn | head

另外tr可以理解的一些字符类如下
alnum 字母和数字
alpha 字母
blank 空格(水平的)
cntrl 控制字符
digit 数字
graph 可印刷字符,不包括空格
lower 小写字母
print 可印刷字符,包括空格
punct  标点符号
space 空格(水平和垂直的)
upper 大写字母
xdigit 十六进制数字

使用方法
tr ' [:classname:] ' 'set1'
比如 tr ' [:punct:] '   ' '

测试了一下,对于openoffice文件 .odt 貌似不太起作用


第16章 正则表达式过滤文本

正则表达式由元字符和普通字符组成。普通字符包括字母,数字,下划线或空格
元字符包括如下几类:
.         可代替除一行之外的任何单个字符
*         可代替零个或多个在它前面出现的字符
[chars]  可代替chars中的任何一个字符,chars 是一串字符序列。可以用-符号来定义一个字符范围
同时,如果^是chars中的第一个字符,那么将匹配没有在chars中指定的字符  [A-Z]
^        匹配一行的开头 如:[^[Tt]he]
$        匹配一行的结尾   [friend$]
\         把\ 后面的字符照常输出,通常用来转义一个元字符  [\$]

一些有用的正则表达式

空白行   /^$/
一整行   /^.*$/
一个或多个空格  /*/
HTML或(XML)标记集  /<[^>][^>]*>/
有效的URL  /[a-zA-Z][a-zA-Z]*: \/\/[a-zA-Z0-9][a-zA-Z0-9\.]*.*/
格式化的美元数  /\$[0-9]*\.[0-9][0-9]/


使用 sed

sed '/pattern/ action' file

' '为pattern正则表达式
action 为操作,有三种
p 打印
d 删除
s 替换

x下面是书中的一个例子

fruite_price.文件内容

Fruit     Price/lbs
Banana 0.89
Paech 0.79
Kiwi 1.50
Pineapple 1.29
Apple 0.99
Mango   2.20

things that are eqal to the same thing are eqal to each other

代码
#!/bin/sh

#打印低于1美元的水果单价表
sed '/0.[0-9][0-9]$/p ' fruit_prices
#默认的sed针对打印操作,对于输入的每一行都进行打印一次
#然后对符合正则表达式的内容行,再打印一次。
#为了撤销这个操作,可以加上选项-n
echo " now,we add choice \"-n\" "
sed -n ' /0.[0-9][0-9]$/p ' fruit_prices

#测试删除操作,不需加选项
#为了更新文件,需要引入临时文件,一般在其后最名加为$$
mv fruit_prices fruit_prices$
sed ' /^[Mm]ango/d ' fruit_prices$ > fruit_prices
echo 
cat fruit_prices$
rm fruit_prices$

#测试替代操作,也不需要加选项-n
#需要注意其中有三个左斜杠
sed 's/Paech/Peach/' fruit_prices

#像上述命令只能替换一行中的第一处错误,如果替换一行中的所有错误
#需要增加选项-g
sed 's/eqal/equal/g' fruit_prices

#s命令提供了&操作,使得可以在匹配串中重复使用
#在价格数字前面增加美元的符号
#在ubuntu上下面的命令居然不可以啊,还是有什么错误???
sed 's/*[0-9][0-9]*\.[0-9][0-9]$/\$&/' fruit_prices

#用选项 -e 可以连接多个命令。
#sed 's/Paech/Peach/' -e 's/eqal/equal/g' fruit_prices
cat fruit_prices
#当然也可以在管道中使用sed,将管道的输出内容,作为sed的输入
#end



阅读(1417) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~