zoukankan      html  css  js  c++  java
  • linux 命令

    sort命令是帮我们依据不同的数据类型进行排序,其语法及常用参数格式:

      sort [-bcfMnrtk][源文件][-o 输出文件] 
    补充说明:sort可针对文本文件的内容,以行为单位来排序。

    参  数:
      -b   忽略每行前面开始出的空格字符。
      -c   检查文件是否已经按照顺序排序。
      -f   排序时,忽略大小写字母。
      -M   将前面3个字母依照月份的缩写进行排序。
      -n   依照数值的大小排序。
      -o<输出文件>   将排序后的结果存入指定的文件。
      -r   以相反的顺序来排序。
      -t<分隔字符>   指定排序时所用的栏位分隔字符。
      -k  选择以哪个区间进行排序。

    列子

    进行/boot目录,根据文件大小的顺序输出,从大到小的顺序输出
    ls -lA |grep ^- |sort -t ' ' -nrk 5
    ls -lA |grep ^- |sort -nrk 5

    -rw-r--r--. 1 root root 43566364 5月 29 2016 initramfs-0-rescue-394ad4829688457ab9375559e4997ede.img
    -rw-r--r--. 1 root root 19813159 5月 29 2016 initramfs-3.10.0-327.el7.x86_64.img
    -rw-r--r--. 1 root root 17740790 5月 29 2016 initramfs-3.10.0-327.el7.x86_64kdump.img
    -rwxr-xr-x. 1 root root 5156528 5月 29 2016 vmlinuz-0-rescue-394ad4829688457ab9375559e4997ede
    -rwxr-xr-x. 1 root root 5156528 11月 20 2015 vmlinuz-3.10.0-327.el7.x86_64
    -rw-------. 1 root root 2963044 11月 20 2015 System.map-3.10.0-327.el7.x86_64
    -rw-r--r--. 1 root root 602631 5月 29 2016 initrd-plymouth.img
    -rw-r--r--. 1 root root 252612 11月 20 2015 symvers-3.10.0-327.el7.x86_64.gz
    -rw-r--r--. 1 root root 126426 11月 20 2015 config-3.10.0-327.el7.x86_64
    -rw-r--r--. 1 root root 166 11月 20 2015 .vmlinuz-3.10.0-327.el7.x86_64.hmac

    ps -aux命令可以看到系统中所有运行的进程信息
    找出3个占用cpu百分比最多的进程名,最后将进程名输出
    ps -aux|sed '1d' |sort -nrk 3 |head -n 3

    找出3个占用内存百分比最多的进程名,最后将进程名输出
    ps -aux|sed '1d' |sort -nrk 4|head -n 3

    df命令是查看系统磁盘的使用情况的,通过上网或者--help的方法查询df命令的使用
    只输出最大的磁盘名
    df -m|sort -nrk 2|head -n 1 |awk '{print $1}'
    输出使用磁盘百分比最大的挂载点
    df -h|sort -nrk 5 |head -n 1|awk '{print $NF}'
    输出可用空间最大的磁盘的挂载点
    df -m|sort -nrk 4 |head -n 1|awk '{print $NF}'

    awk
      • -F fs or --field-separator fs
        指定输入文件折分隔符,fs是一个字符串或者是一个正则表达式,如-F:。
      • -v var=value or --asign var=value
        赋值一个用户定义变量。
      • -f scripfile or --file scriptfile
        从脚本文件中读取awk命令。
      • -mf nnn and -mr nnn
        对nnn值设置内在限制,-mf选项限制分配给nnn的最大块数目;-mr选项限制记录的最大数目。这两个功能是Bell实验室版awk的扩展功能,在标准awk中不适用。
      • -W compact or --compat, -W traditional or --traditional
        在兼容模式下运行awk。所以gawk的行为和标准的awk完全一样,所有的awk扩展都被忽略。
      • -W copyleft or --copyleft, -W copyright or --copyright
        打印简短的版权信息。
      • -W help or --help, -W usage or --usage
        打印全部awk选项和每个选项的简短说明。
      • -W lint or --lint
        打印不能向传统unix平台移植的结构的警告。
      • -W lint-old or --lint-old
        打印关于不能向传统unix平台移植的结构的警告。
      • -W posix
        打开兼容模式。但有以下限制,不识别:/x、函数关键字、func、换码序列以及当fs是一个空格时,将新行作为一个域分隔符;操作符**和**=不能代替^和^=;fflush无效。
      • -W re-interval or --re-inerval
        允许间隔正则表达式的使用,参考(grep中的Posix字符类),如括号表达式[[:alpha:]]。
      • -W source program-text or --source program-text
        使用program-text作为源代码,可与-f命令混用。
      • -W version or --version
        打印bug报告信息的版本。

    1、去重,有多行一样的只显示一行
    sort 1.txt | uniq
    2、输出行重复的次数,按重复次数从大到小的顺序输出
    cat 1.txt |sort |uniq -c //显示每一项重复的次数
    cat 1.txt |sort |uniq -c |sort -rnk 1

    3、输出独一无二的行,即没有重复的行
    cat test.txt |sort |uniq -u

    windows:
    1、excel、word

    linux:

    通过uniq --help或者上网去学习uniq命令的使用

    ##################################################################################

    unix2dos //从linux转换到windows 原理:在换行符前面加上回车符^M

    dos2unix //从windows转换到linux 原理:去掉每一行的回车符^M

    grep  '模式'   文件
    grep   [选项]  '模式'   文件
    
    
    选项
    -n     显示被匹配到的内容所在的行号
    -o     只显示被匹配到的内容
    -v     取反,取匹配到行之外的外,
    
    模式可以使用单引号,也可以使用双引号
    一般我们就使用单引号
    
    
    模式
    1、可以一个明确的字符或者字符串
    如:grep  'root'   file           //会将含有root的行全部输出
        grep  -n   'root'   file      //将含有root行输出,并打印行号
    	
    
    基本正则表达式,	
    元字符
    ^      行起始标记                                  如^root匹配以root开头的行  
    $      行尾标记                                    如root$匹配以root结尾的行
    .      任意一个字符                                如wor.d能够匹配world,worad、worbd等,因为.能够匹配任意一个字符
    []     匹配包含在[字符]之中任意一个字符	           如a[ab]c能够匹配aac或abc
    [^]    匹配[^字符]里面字符之外的任意一个字符       如a[^ac]c,能够匹配a.c,但是.不能够是a或者c,  能匹配 a1c 、a2c 、 afc等只要中间不是a或者c都可以
          转义字符                                    可以将上面的无字字符进行转义,如'$'可以忽略$的特殊意义
    *      匹配之前的项0次或者多次                     如ft*  可以匹配f     ft     ftt     fttt        fttttttttttttttttt             
    
    
    【.*    任意个字符,0个或者多个】
    
    安装httpd,将它的主配置文件,复制到/opt目录
    练习:
    1、只查看文件中含有Listen的行
    2、只查看文件中以Listen开头的行
    3、只查看以数字结尾的行
    4、查看以<开头并且以>结尾的行
    5、查看文件中含有if或者If的行                     ##grep '[Ii]f'  file.txt
    6、不显示文件中以#号开头的所有内容                ##grep '^#'  -v
    7、不显示文件里的空白行                           ##grep '^$'  -v
    8、使用ifconfig命令结合grep命令的方式,输出系统中所有的网卡
    9、使用date命令结合grep的方式,输出系统中的时间   ##date |grep '[0-9][0-9]:[0-9][0-9]:[0-9][0-9]' -o
    
    
    
    
    扩展的正则元字符
    (要使用扩展正则表达式,3种方式,
    1、使用egrep命令
    2、使用grep  -E 
    3、使用grep命令,但是遇到元字符的时候、就要加上转义
    
    ?        匹配之前的项0次或者1次         
    +        匹配之前的项1次或者多次           
    {n}      匹配之前的项n次
    {n,m}    匹配之前的项n到m次,包括n或者m
    {n,}     匹配之前的项n任意次
    ()       "组"字符串,如(ab)*,代表0个或者多个ab的组合
    |        或者,即匹配|两边的任意一项
    
    <>       <内容>中的内容必须以单词出现,<和>都需要加上转义字符
    
    
    练习:
    1、查看文件中,以2个数字结尾的行
    2、显示/etc/passwd文中的两位数或者三位数
    3、通过shell脚本,让用户输入,判断用户输入的是否是一个合格的纯数字
    
    
    
    
    a-z       ==     [:lower:]
    A-Z       ==     [:upper:]
    a-zA-Z    ==     [:alpha:]
    0-9       ==     [:digit:]
    特殊符    ==     [:punct:]
    
    
    s     表示空白符
    
    1、过滤下面文本的ip地址
    aoot:x:0:0:Root:/aoot:$/bin/bash
    root:x:0:0:root:/root:/bin/bash
    x:0:0:root:/root:/bin/bash/root
    root:0:0:root:/root:/bin/bash/root
    ftp:x:14:50:FTP ^User:/var/ftp:/sbin/nologin
    fap:x:14:50:FTP 256.258.1.2  U$ser:/var/ftp:/sbin/nologin
    192.168.100.140   252130613a1
    0.0.0.127   13608001910
    172.16.299.1  00.00.00.00:00:00
    169.169.1.2
    aabc$
    
    
    [第一段].[第二段].[第三段].[第四段]
    
    1位数:0-9
    2位数:10-99
    3位数:1xx    200-249    250-255
    
    
    
    tr的作用
    
    1、替换,只能替换单个字符
    echo abc | tr  'a-z'  'A-Z'
    a--->A
    b--->B
    
    cat file | tr 'a-z'  'A-Z'    将文本里的全部小写转换成大小
    cat file | tr 'A-Z'  'a-z'    将文本里的全部小写转换成大小
    
    
    2、删除作用,也只是删除单个字符
    tr   -d    '参数'
    tr   -d  'a-z'   删除全部的小写字母
    tr   -d  '0-9'   删除全部的数字
    
    
    3、压缩后再替换
    tr -s  '
    '   ','        #先将多个连续的
    换行符压缩,压缩之后再进行替换

    .          任意单个字符
    *          匹配前面的项0次到多次
    []         匹配[]内的任意单个字符
    [^]        排除[]内的任意单个字符
    
    ^          以什么开头
    $          以什么结尾
    
    ()       可以加入元字符,串组       
    
    
    ?          匹配前面的项0次到1次
    +          匹配前面的项1次到多次
    {n,m}      匹配前面的项n次到m次
    
    <>          
    
    grep匹配的原则:采用贪婪模式,会进行最长的匹配
    
    
    
    -B  n    将匹配内容所有的行的前面n行也进行输出
    -A  n    将匹配内容所有的行的后面n行也进行输出
    -C  n    将匹配内容所有的行的前后n行也进行输出
    
    
    -v       将匹配内容所有行之外的行输出
    -E       启动扩展正则支持
    -i       忽略大小写
    
    -n       将匹配的模式所有的行号也进行输出
    
    -o       仅显示被匹配到的内容
    -c       统计被匹配到的内容一共有多少
    
    -f  file    使用指定的文件里的模式,如果有项,写到多行,最终进行或关系的查询
    
    -H       输出每一个被匹配到的行前面加上它所在的文件名
    
    
    -l       仅仅输出匹配到的模式所在的文件名,只输出文件名
    -L       ~~~~~~~~~~~~~~~~
    -w       当后面的模式为一个单词,才算匹配到
    
    
    
    
    
    
    
    文本处理
    
    grep   vim   
    
    cat  
    tac  
     
    head  -n  a   ##输出前面a行
    tail  -n  a   ##输出后面a行
    
    
    
    
    sed命令
    
    
    sed  [选项]   'command'    ......
    
    动作:
    p      打印输出
    d      删除操作
    a      在指定的行后面添加一行内容
    i      在指定的行前面添加一行内容
    
    
    
    
    1、查看操作
    sed  -n   '5p'   file     //只查看文件的第5行
    sed  -n   '3,5p'  file    //查看文件的第3到第5行
    sed -n '5,$ p'   file     //打印第5到最后一行
    
    
    
    2、删除操作
    sed '3 d' 1.txt       //删除文件的第3行 ,然后将内容进行输出,不是直接操作的文件,
    sed '3,5 d' 1.txt
    sed '3,$ d' 1.txt
    
    sed在操作文件,只有加上-i选项才是直接操作
    
    
    
    3、添加操作
    
    sed  '2a word'  file           //在第二行后面添加一行,内容为word   ,即添加的内容为第三行
    sed  '3i word'  file           //在第三行前面添加一行,内容为word   ,即添加的内容为第三行
    
    
    思考:怎么在指定行后面添加2行内容
    
    
    
    3、查找操作
    sed  -n  '/root/p' file       //只输出root关键字的行
    
    sed  '/root/d'  file                    //将含有root的行删除,然后输出,,加上-i可以操作原文件
    
    
    4、替换操作
    sed 's/root/new/'   file            //将文件中的root替换成new,每行只替换一次,加上-i可以操作原文件
    sed 's/root/new/g'   file            //将每行的所有root全部替换成new
    sed '3,4s/root/new/g' 1.txt          //只替换第3到第4行的root为new
    
    
    
    
    练习:
    1、selinux配置文件的SELINUX默认的值为enforcing,使用sed将其修改为permissive
    将/etc/passwd复制到/opt目录进行操作
    2、使用sed命令输出/etc/passwd的第5到第7行的内容
    4、将passwd文件中第2到第3行的所有d替换成DD
    
    
    
    5、只输出passwd文件的第6段内容
    cat /etc/passwd|grep '/.*' -o |sed 's/:.*//'
    
    
    cat /etc/passwd | cut -d ':' -f 6
    
    了解一下cut命令的使用方法
    
    
    
    
    
    
    思考:
    
    1.将/etc/passwd最后一段全部改成/bin/bash
    
    cat /etc/passwd|sed  's/(.*:)(.*)/1/bin/bash/'
    cat /etc/passwd|grep '(.*:)' -o  |sed 's/$//bin/bash/'
    
    1  代表前面第一个小括号中匹配的内容
    2  代表前面第二个小括号中匹配的内容
    
    &   代表所有匹配的内容
    
    
    
    2.将/etc/passwd每行前面的用户名,添加到最后一段
    如:root:x:0:0:root:/root:/bin/bash
    处理后应该为
        root:x:0:0:root:/root:/bin/bash:root
    
    	
    3.一文本内容如下:
    192.168.100.2
    172.16.5.4
    10.101.2.5
    133.37.25.21
    
    通过命令将其处理成如下效果(转换到一行,通过逗号隔开,每行内容用单引号引起来):
    '192.168.100.2','172.16.5.4','10.101.2.5','133.37.25.21'
    
    
    cut命令,以指定分隔符分隔的段输出
    
    cat /etc/passwd |cut -d ':' -f 7    //只看第7段的内容
    cat /etc/passwd |cut -d ':' -f 1,3,5   //只看第1段、第3段、第5段
    
    cut -d ':' -f 1-5   //第一到第5段
    cut -c  1-5     //输出每行前面的第1到第5个字符
    cut -c 3-       //输出第3个字符到最后一个字符

    tac cat反向输出


  • 相关阅读:
    C# 根据节点索引访问XML配置文件
    C# AE 关于TOCControl
    C# AE 实现点选框选/点击选择要素
    C# AE 合并要素/合并图形/merger功能
    C# AE 对图层筛选要素后显示/只显示符合条件的要素
    css实现垂直水平居中的几种方法
    js中的DOM节点----文本节点
    js中的DOM节点操作---增删改查
    js中的6中继承方式
    js中的原型对象---prototype
  • 原文地址:https://www.cnblogs.com/hywhyme/p/6230636.html
Copyright © 2011-2022 走看看