zoukankan      html  css  js  c++  java
  • 我的经常使用linux小命令

        这里并非系统具体介绍每个Linux命令,不过记录本人在平时工作中经经常使用到的一些比較基础的命令及相关的參数,同一时候用了一些简单的样例来说明这些命令的用途,以及怎样用多种命令来实现同一种功能。

    1、ls命令
        要显示当前文件夹下的文件列表时,我常常就使用ls命令的下面三个參数。
    -l 使用长列表格式
    -h 文件大小以人可读的方式打印
    -t 以最后改动时间排序,最新的放在最前
        使用样例,怎样显示当前文件夹下的文件夹?
            方法1: ls -l | grep '^d'
            方法2: ls -l | awk '/^d/'

    2、grep命令
        当须要找出匹配指定模式的文件时,常常会用到grep命令的下面几个參数。
    -w 全然匹配整个单词,而不是字符串的一部分,若要匹配abc,则不会匹配abcd
    -i 忽略大写和小写
    -n 显示指定模式在匹配文件里的行号
    -v 反向匹配,即匹配不符合的行
    -f 从文件里获取待匹配的模式
        使用样例:
        grep ^$ file 匹配文件file中的全部空行
        grep -v '^$' file 匹配文件file中的全部非空行
        grep '[^^$]' file 匹配文件file中的全部非空行
        grep -vf t2 t1 获取t1中跟t2数据不匹配的数据,即获取在t1,但不在t2的数据
        正則表達式[^$]表示匹配空行,前面加上^即表示不匹配空行

    3、排序去重命令 sort vs uniq
        sort 命令用来对数据进行排序。
    -t 用于指定域的分隔符
    -n 以数字方式进行比較,而不是字符比較
    -r 反向排序
    -u 去除反复的行
    -k 以指定的域開始进行排序,域从1開始
    +表示以第几域排序,-表示不以第几域排序,如 sort +0 -2 +3则表示以第0域開始排序,略过第2域,然后再使用第3域排序
        uniq 用于删除文本文件里的连续反复的行,一般使用sort之后再调用uniq。
    -d 仅显示反复一次的行
    -c 打印每一反复行出现的次数
        sort -u 和uniq的差别在于,uniq仅去除连续反复的行,而sort -u会去除整个文本中全部反复的行,比如,
    #源文件file1中的内容
    hello world
    Good morning
    Good morning
    hello world
    #使用sort -u < file1的结果例如以下:
    hello world
    Good morning
    使用uniq < file1的结果例如以下:
    hello world
    Good morning
    hello world
    4、tr命令
        当须要进行一些简单的字符串替换和删除时,tr命令就会显得很实用。
        比如,以下的tr操作都是没有直接改动源文件,改动则须要文件重定向
    tr 'A-Z' 'a-z' < file 将字符串的大写字母都转为小写字母:
    tr -s ' ' ' ' < file 把多个连续空格替换成单个空格,-s选项可将多个连续字符替换为一个指定字符
    tr -s '
    ' < file 删除空行
    tr -d '[0-9]' < file 删除全部数字,-d选项能够删除指定的字符
    5、tail命令
        tail命令用于显示文件末尾指定区域的内容,如tail -10 file, 表示显示文件file最后10行内容,tail命令有非常多參数,当中有一个常常使用并且非常好用的參数 "-f":
    tail -f 动态显示文件新增的内容
        该參数作用是不返回文件结束符,并动态显示文件新增的内容,须要结束时,须要用户手动进行中断。这个命令在显示日志的时候作用就很明显,对于一个执行中的server,可能会不断将server当前执行状态和错误状态写入日志文件,使用tail -f,将会以一定的时间实时追踪该文件的全部更新。

    6、find命令
        在查找文件文件的时候,首先会想到是使用find命令。       
    -name 依照文件名称查找文件
        比如,查找当前文件夹下名字以cpp结尾的文件
        find . -name "*cpp" | xargs grep "abc"
        有些系统对參数的长度有限制,xargs命令的作用是将參数列表转换成小块分段传递给其它命令,以避免參数列表过长的问题。上面的find中,当前文件夹下可能包括非常多名字以cpp结尾的文件,因此为了避免“參数列太长”或“參数列溢出“的错误,使用xargs来接收find命令的输出。

    7、alias命
        alias命令用于设置命令的别名。利用alias能够把非常长的命令变成随意简短的命令。
        若要加入自己的alias,格式例如以下
    alias ll="ls -lht"
        上述加入alias的操作,在用户退出后就变为无效了,若要永久生效,能够改动配置文件~/.bashrc文件(仅改动用户自己),在文件最后面加上你自定义的alias,如:
    alias la="ls -al --color=auto"
        本次改动,要在下次登录的时候才干生效。若要立即生效,能够输入:
    source ~/.bashrc

    8、进程相关命令  
        ps命令用于查看当前执行的进程。
    ps -ef 显示系统执行的进程
        top 用于查看当前进程执行情况,包含内存使用、cpu使用量、交换区使用量等。
    shift + m 能够按内存占用量来排序进程,查找进程内存使用量就最实用了
    q 退出

    9、经常使用快捷键
    Ctrl + z 将当前程序放到后台并挂起
    Ctrl + d 输入文件结束符,在命令行中直接输入Ctrl + D,即退出shell
    Ctrl + a 跳到命令行的头部位置
    Ctrl + e 跳到命令行的尾部位置
    Ctrl + w 删除一个单字(word)
    Ctrl + u 删除光标到行首的字符
    Ctrl + k 删除光标到行末的字符
    Ctrl + c 中断当前程序

    10、任务命令
        命令运行顺序
    && 第一个命令成功才运行第二个命令
    || 第一个命令失败才运行第二个命令
    jobs 查看挂起的当前的任务列表
    fg + N  将第N个任务放到前端,唤醒Ctrl + z挂起的任务

    11、vim命令
    !%xxd 以十六进制的方式查看文件内容
    ! 后面加上shell命令就而已运行对应的shell命令
    * 将光标移至下一个匹配的单词
    # 将光标移至上一个匹配的单词
    [[ 光标跳到函数的开头
    ]] 光标调到函数的结尾说
    [{ 光标跳到上一个作用域的开头
    ]} 光标跳到下一个作用域的开头
    ggvG或者ggVG 全选并高亮
    gg=G 对整个文件内容进行格式化缩进
    u 撤销上一个动作
    Ctrl + r 取消上一个撤销动作
    set scb 同步两个屏幕的文件,当中一个文件移动,则令一个文件跟着移动,对照两个文件时经常常使用到,解开分屏set scb!
        两个非常好用的插件ctag和Tlist:
       ctags
            功能是扫描指定的源文件,找出当中所包括的语法元素,并将找到的相关内容记录下来。记录的内容包括:宏定义、枚举型、变量的值、函数的定义、原型和声明、namespace、typedefs变量 、类、结构、枚举类型和联合 类、结构和联合中成员变量或函数等。通过ctags我们能够非常easy的找到某个变量或者函数等在哪个文件定义。

       Tlist
            在当前vim中,新开一个区域,显示了当前文件的函数、类、全局变量等定义,输入回车就可以跳转到对应内容的起始位置。平时在查找某个函数时,就能够用到了。

    12、shell中凝视一块代码
       行凝视
            shell中默认提供的凝视方法是#,作用是凝视一行,比如
    #这里是一行凝视
    if [ "1" = "2" ]; then
        DoSomething
    fi
       块凝视
            shell中并没有提供块凝视的方法,可是我们能够使用还有一种方法来实现块凝视,这样的叫做here document。here document表示包括的这段内容是一个总体数据。以下代码中,两个document之间的内容是一个总体数据。
    <<document
            ....
    document
        here document,<<符号表示这是一个文本内容,由其后的字符串包括的范围就是文本的正文,:符号表示空命令,什么都不干,以下的意思就是将一个文本传给空命令,即对文本不做不论什么处理,间接就等于凝视了
    :<<block
        code
    block
        避免反引號不能被凝视的做法是加上单引號
    :<<block'
        code
    'block

    一些小问题
        问题1: 怎样删除文件里的全部空行?
    1、sed '/^$/d' file 对匹配的空行运行删除操作
    2、awk '/./ {print $0;}' file 匹配除空白换行字符外的全部字符,即匹配非空行
    3、awk '/[^^$]/{ print $0; } file
        问题2: 怎样删除文件名称带空格的文件,如"a b.html"s?
    1、对空格进行转义,即空格前加上反斜杠,能够用反斜杠来屏蔽特殊字符
    2、使用双引號括住文件名称
    3、使用单引號括住文件名称
        问题3:
             一个傻x错误,在运行一段代码后,然后推断$?是否为0,以决定前面的功能代码是否运行成功,可是发现什么情况下都是返回成功,查了好久,原来是在推断$?之前,使用了echo输出 $?,所以永远都是为真了

  • 相关阅读:
    将ObservableCollection(Of T) 数据 绑定到 Canvas
    StylusNodeJS下构建更富表现力/动态/健壮的CSS
    string引用类型
    c#之预处理器指令
    c#继承与构造函数
    c#构造函数
    c#之扩展方法
    c#之结构
    继承与重写
    dedict: 很有新意的图形化英汉字典
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/3830855.html
Copyright © 2011-2022 走看看