split,tr,cut,tac

split:

标志
  注:-b 和 -l 标志是互斥的。
  -a SuffixLength 指定用于形成输出名称文件后缀部分的字母数。字母数确定可能的输出文件名组合数。缺省是两个字母。
  -b Number 将文件分割成 Number 变量指定的字节数。将 k(千字节)或 m(兆字节)乘数加到 Number 值的末尾使文件分别分割成 Number*1024 字节或 Number*1,048,576 字节的几个段。
  -l LineCount 指定每个输出文件的行数。缺省值是 1000 行。
  退出状态
  该命令返回以下退出值:
  0 命令成功运行。
  >0 发生错误。

  1. 要将文件分割成 1000 行的段,请输入:
  split book
  此示例将 book 分割成 1000 行的段,命名为 xaa、 xab、 xac 等等。
 2. 要将文件分割成 50 行的段并指定文件名前缀,请输入:
  split -l 50 book sect
  此示例将 book 分割成 50 行的段,命名为 sectaa、sectab、sectac 等等。
 3. 要将文件分割成 2KB 的段,请输入:
  split -b 2k book
  此示例将 book 分割成 2*1024 字节的段,命名为 xaa、xab、xac 等等。
 4. 要将文件分割成 676 个以上的段,请输入:
  split -l 5 -a 3 book sect
  此例将 book 分割成 5 行的段,命名为 sectaaa、sectaab、 sectaac 等等,直到 sectzzz(最多 17,576 个文件)。
  该命令包含在/usr/bin/split 。



tr:

  -c 用字符串1中字符集的补集替换此字符集,要求字符集为ASCII。
  -d 删除字符串1中所有输入字符。
  -s 删除所有重复出现字符序列,只保留第一个;即将重复出现字符串压缩为一个字符串。
  file是转换文件名。虽然可以使用其他格式输入,但这种格式最常用。


 字符范围
  指定字符串1或字符串2的内容时,只能使用单字符或字符串范围或列表。
  [a-z] a-z内的字符组成的字符串。
  [A-Z] A-Z内的字符组成的字符串。
  [0-9] 数字串。
  \octal 一个三位的八进制数,对应有效的ASCII字符。
  [O*n] 表示字符O重复出现指定次数n。因此[O*2]匹配OO的字符串。
  tr中特定控制字符的不同表达方式
  速记符含义八进制方式
  \a Ctrl-G 铃声\007
  \b Ctrl-H 退格符\010
  \f Ctrl-L 走行换页\014
  \n Ctrl-J 新行\012
  \r Ctrl-M 回车\015
  \t Ctrl-I tab键\011
  \v Ctrl-X \030
  应用例子
  (1)去除oops.txt里面的重复的小写字符 ( # -s会保留第一个字符)
  [root@localhost ~]# cat oops.txt
  ddddfffabccccc
  lerrrrdddd
  [root@localhost ~]# tr -s "[a-z]" < oops.txt > result.txt
  [root@localhost ~]# cat result.txt
  dfabc
  lerd
  (2)删除空行
  [root@localhost ~]# cat oops.txt
  ddddfffabccccc
  lerrrrdddd
  [root@localhost ~]# tr -s "[\012]" < oops.txt > result.txt
  [root@localhost ~]# cat result.txt
  ddddfffabccccc
  lerrrrdddd
  (3)删除所有空行
  [root@localhost ~]# cat oops.txt
  ddddfffabccccc
  lerrrrdddd
  [root@localhost ~]# tr -d "[\012]" < oops.txt > result.txt
  [root@localhost ~]# cat result.txt
  ddddfffabccccclerrrrdddd
  (4)小写到大写
  [root@localhost ~]# cat oops.txt
  ddddfffabccccc
  errrrdddd
  [root@localhost ~]# cat oops.txt | tr "[a-z]" "[A-Z]" > result.txt
  [root@localhost ~]# cat result.txt
  DDDDFFFABCCCCC
  ERRRRDDDD
  (5)删除指定的字符(# -d 与 -s 不同,-d会全部删除,但-s会保留第一个)
  [root@localhost ~]# cat oops.txt
  ddddfffabccccc
  errrrdddd
  [root@localhost ~]# cat oops.txt | tr -d "[bd]" > result.txt
  [root@localhost ~]# cat result.txt
  fffaccccc
  errrr
  [root@localhost ~]# cat oops.txt | tr -s "[bd]" > result.txt
  [root@localhost ~]# cat result.txt
  dfffabccccc
  errrrd



cut:


 范例:
  shell>> cat example
  test2
  this is test1
  shell>> cut -c1-6 example ## print 开头算起前 6 个字元 从1开始计数
  test2
  this i
  可以将一行分割成多列,通过-d ':',将分隔符改为:。再通过-f n指定选用的列。
  如:
  $ echo 12:00:01 | cut -d ':' -f 2
  00
  Cut()


tac:

# cat a.txt //显示文件内容
  1
  22
  333
  4444
  55555
  # tac a.txt //反序输出文件内容
  55555
  4444
  333
  22
  1




你可能感兴趣的:(职场,split,tr,cut,休闲)