Chinaunix首页 | 论坛 | 博客
  • 博客访问: 323180
  • 博文数量: 240
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 50
  • 用 户 组: 普通用户
  • 注册时间: 2016-08-04 18:14
文章分类

全部博文(240)

文章存档

2017年(8)

2014年(4)

2013年(15)

2012年(4)

2011年(14)

2010年(55)

2009年(140)

我的朋友

分类: LINUX

2013-08-08 01:36:54


一、正则表达式:
  1. .任意字符
  2. ^行首匹配
  3. $行尾匹配
  4. ^$表示空行,不含字符的行
  5. ^ $匹配只有单个空格的行
  6. [0-9]
  7. [a-zA-Z]
  8. ^[A- Z]搜索以大写字母开头的行
  9. [^A-Z]匹配大写字母意外的任意字符
  10. *表示匹配0个或若干个字符,如:a*,表示匹配0个或若干个a; aa*表示匹配至少1个a
  11. .*来表示0或若干个任意字符
  12. e.e*表示匹配第一个e和最后一个e之间的任意字符
  13. [-0-9]匹配一 个连字符或数字
  14. []a-z]匹配一个]或者字母
  15. {min,max}匹配任意数目的字符串
  16. [a-z]{10}只匹配10个 a-z字符的字符串
  17. s/.{5}$// 删除每行的最后5个字符
  18. (...),n是1到9的数字,表示存储用的寄存器,用n来引 用存在寄存器中的内容
  19. ^(.)1匹配行首的第一个字符,并将该字符存到1号寄存器中,然后匹配1号寄存器中的内容,这由1的描述。该正则 表达式的最终效果是,如果一行的头两个字符相同,就匹配他们。
  20. ^(.).*1$匹配一行中的头一个字符(^.)跟最后一个字符(1$)相 同的行。.*匹配中间的所有内容
  21. ^(...)(...)行中头三个字符存在1号寄存器,接着的三个字符存在2号寄存器.
  22. s/(.*) (.*)/2 1/g 交换两个字段
  23. .任何字符
  24. ^行首
  25. $行尾
  26. *前导的正则表达式重复0或若干次
  27. [字 符表]字符中的任一字符
  28. a..表示a后的2个字符
  29. ^wood表示行首的wood
  30. x$表示行为的x
  31. ^INSERT$只包含 字符串INSERT的行
  32. ^$不包含任何字符的行
  33. x*表示0或若干个连续的x
  34. xx*表示1或多个连续的x
  35. .*表示0活若干 个字符
  36. w.*s表示以w开始,s结尾的任何字符串
  37. [tT]小写或大写的t
  38. [^字符表]表示任一不在字符表中的字符 [^0-9] [^a-zA-Z]
  39. {min,max}表示前导的正则表达式重复只烧min次,至多max次[0-9]{3,9}表示3到 9个数字
  40. (...)表示将小括号中匹配的字符串存储到下一个寄存器中(1-9),
  41. ^(.)表示行中第1个字符存到1号寄存器
  42. ^ (.)1表示行首恋歌字符,且他们相同

二、cut 指令

  1. cut -c5 file把file文件中没行的第5个字符析取出来;
  2. 用逗号分割的数 值列表,如-c1,13,50把第1,13,50个字符析取出来
  3. cut -c20-50把第20到50之间的字符析取出来
  4. who | cut -c1-8
  5. who | cut -c1-8,18- 析取行中的第1到8个字符(用户名)和第18到行尾的字符(登录时间)
  6. cut -ddchar -ffields file其中,dchar是数据中分割各字段的分割符,fields表示要从文件file中析取出来的字段.
  7. 字 段编号从1开始,而且格式跟以前将的用来指定字符位置的数字一样(如-f1、2、8、-f1-3、-f4-)。
  8. cut -d: -f1 /etc/passwd
  9. 如果已知字段之间使用制表符分隔的,就可以给cut命令用-f选项而不用-c选项,好多了!还记得吧,这里用不着用-d选 项来指定分割符,因为
  10. cut把制表符默认为分割符。

三、paste 指令

  1. paste和cut正好相反,它不是把行分离开,而是把多行合并在一起。
  2. paste names numbrs文件names中的每一行都和numbers中的对应行显示在一起,中间用制表符分割。
  3. 如果不想用制表符作默认分割, 可以使用-dchars指定分割符
  4. paste -d\'+\' names addresses numbers
  5. -s选项告诉paste把同 一文件中的行粘贴在一起,而不是从其他文件。如果只指定一个文件名,其效果是把文件中的所有行合并成一行,原来隔行之间用制表符或者有-d选项指定的分割 符分割。
四、sed 指令:

  1. sed是用来编辑数据的程序,意指流编辑器(stream editor)。与ed不同,sed不能用于交互,
  2. -n选 项,然后使用p命令显式指定
  3. sed -n \'1,2p\' file只显示前2行
  4. sed -n \'/Unix/p\' file只打印包含Unix的行
  5. 删除行
  6. d删除整行文件
  7. sed \'1,2d\' file删除1和2行
  8. 记住sed默认把输入 的所有行写入标准输出,所以生于行的文字,也就是从第3行到结尾,都被写入标准输出。
  9. sed \'5d\'删除第5行
  10. sed \'/[Tt]est/d\'删除包含test或Test的行
  11. sed -n \'20,25p\' test只显示文件test的第20行到第25行
  12. sed \'1,10s/unix/UNIX/g\' intro报intro前10行中的unix改为UNIX
  13. sed \'/jan/s/-1/-5/\'将所有包含jan的行中第1个-1改为-5
  14. sed \'s/...//\' data删除data文件每一行的前3个字符
  15. sed \'s/...$//\' data删除data文件每一行的最后3个字符
  16. sed -n \'I\' text显示文件text的所有行,把所有不可打印字符显示为nn,制表符显示为t
五、tr 指令

  1. 过滤器tr用来转换来自标准输入的字 符,tr命令的一般格式为
  2. tr from-chars to-chars
  3. tr e x < intro把所有字母e转换成x
  4. tr命令的输入必须重定向到文件intro,因为tr总是从标准输入获得输入;转换的结果写入标准输出,而原始文 件保持不变。
  5. cut -d: -f1,6 /etc/passwd | tr : \' \' 通过在管道线的最后加上适当的tr命令,就可以把冒号转换成制表符,这样产生的输出更容易看
  6. 单引号中括的是制表符(尽管你看不到)。必须将它括在 引号中,以便穿过shell,使tr有机会看到它。
  7. 使用nnn来给tr提供8进制表示的字符
  8. 一些ascii字符的八进制值
  9. 响 铃 7
  10. 退格 10
  11. 制表符 11
  12. 新行 12
  13. 换行 12
  14. 换页 14
  15. 回 车 15
  16. 转义 33
  17. date | tr \' \' \'12\'此例中,tr接受date命令的输出,并把所有的空格转换成换行
  18. tr \'[a-z]\' \'[A-Z]\'
  19. -s选项,tr命令中的-s选项用来压缩to-chars中重复的字符,换句话说,如果转换完成后,有 to-chars中的某个字符连续出现多次,则这些连续相同的字符被替换为一个字符。
  20. 如下面的命令将冒号转换为制表符,并将多个连续制表符替换为 单个制表符:
  21. tr -s \':\' \'11\'
  22. tr -s \' \' \' \'
  23. -d选项用来删除掉输入流中的字符,其一般格式为
  24. tr -d from-chars任何列在from-chars中的字符都会被从标准输入中删除。下例用tr来删除文件intro中的所有空格:
  25. tr -d \' \'
  26. 当然sed \'s/ //g\' intro也可以得到同样的效果
  27. tr \'X\' \'x\' 把大X专成小x
  28. tr \'()\' \'{}\' 把所有左小括号转换成左大括号,右小括号专成右大括号
  29. tr \'[a-z]\' \'[A-Z]\' 把小写转大写
  30. tr \'[A-Z]\' \'[N-ZA-M]\' 把A-M字母分别专成N-Z把N-Z转成A-M
  31. tr \' \' \'\'把所有制表符转换成空格
  32. tr -s \' \' \'\'把多个空格转换成单个空格
  33. tr -d \'14\' 删除所有换页字符(八进制14)
  34. tr -d \'[0-9]\'删除所有数字

六、grep 指令

  1. grep \'[A-Z]\' list list中包含一个大写字母的行
  2. grep \'[0-9]\' data中包含数字的行
  3. grep \'[A-Z]...[0-9]\' list list中包含以大写字母开始、数字结尾的5个字符组合的行
  4. grep \'.pic$\' filelist filelist中以.pic结尾的行
七、uniq 指令

  1. uniq in_file out_file该格式中,uniq把in_file复制到out_file,处理过程中,去掉其中的重复行。如果不指定第2个参数out_file,结 果就写入标准输出;如果in_file没有指定,那么uniq就成了一个过滤器,从标准输入读取输入。
八、重定向指令

  1. >或< 重定向,覆盖原有的内容
  2. >>或<< 重定向,想文件末尾追加内容
  3. tee 显示在终端上的内容存储到文件 ls | tee >glx

九、test 指令:

  1. -d 目录
  2. -e 存在
  3. -f 普通文件
  4. -r 进程可读文件
  5. -s 长度不为0
  6. -w 进程可写文件
  7. -x  可执行
    -L  链接文件

十、参数指令

  1. # 传给程序的参数个数,或者执行set命令设置的参数个数
  2. $* 对位置参数等的集中引用
  3. $@ 跟$*相似,区别在于当加入双引号后("$@"),集中引用位置参数"$1","$2"...等
  4. $0 正执行的程序名
  5. $$ 正执行程序的进程id
  6. $! 最后一个发生后台运行的程序的进程id
  7. $? 最后一个在前台执行的程序的退出状态
  8. $- 当前有效选项标志

十一、字符&整数串比价


  1. 字符串比较
  2. s1 = s2 s1等于s2
  3. s1 != s2 s1不等于s2
  4. s1 s1不为空
  5. -n s1 s1不为空
  6. -z s1 s1为空
  7. 整数比较操作
  8. -eq 等于
  9. -ge 大于或等于
  10. -gt 大于
  11. -le 小于或等于
  12. -lt 小于
  13. -ne 不等于
  14. [ "$x1" = 5 ]字符串比较
  15. [ "$x1" -eq 5 ]整数比较
  16. -a 逻辑与操作
  17. -o 逻辑或操作
  18. a 逻辑与操作
  19. -o 逻辑或操作

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