Unix命令为我们的工作提供了极大的便利。这里分享10个Unix命令小窍门,让我们一起将大工作量变得更快速。文件每一行显示最后一个字如果你知道$NF,这个技巧就相对简单。 awk '{print $NF} awk -F: '{print $NF}' NF编程代表字段数(e.g., 5),因此,$NF 代表字段值 (e.g., $5)。 $ cat numbers 1 2 3 4 5 one two three four five $ awk '{print $NF}' numbers 5 five 这个技巧,在打印文件最右边的字时很有帮助,即使是每行包含不同字数的词,也可用。如果你想打印其他行末的词,也可以使用NF作为字段选项的锚。在这个命令中,我们使用NF-1选择最后一个字段. $ awk '{print $(NF-1)}' numbers 4 four 删除Nth行从文件中删除特定行应该是一个很简单的操作。在下面的例子中,确保是1到11的文件数,一个数字一行。使用命令,像是,第七行像是,"7d"命令就是删除第七行,示例如下: $ sed -i '7 d' numbers $ cat numbers 1 2 3 4 5 6 8 9 10 11 你可以使用范围删除一个序列行,命令是【sed -i '7,9 d' numbers】,意思是删除7至9行。 删除空白行删除文件中的空白行方法有很多,我使用最简单的一个。在下面的命令中,使用 ^$代替行空白。^ 代表一行的开始,$ 代表一行的结束,因此,一行的开始结束中,没有东西,为空白。 $ cat strings This is the last day of your life thus far Mr. Logic $ sed -i '/^$/d' strings $ cat strings This is the last day of your life thus far Mr. Logic 使用 sed命令(如下),可以删除空白行并备份原文件。 $ perl -i.bak -n -e'print if /\S/' strings $ ls -l strings* -rw-r----- 1 shs faculty 53 Jan 4 2015 strings -rw-r----- 1 shs faculty 54 Jan 4 18:36 strings.bak 值得注意的是,单个空白行删除,文件比原文件要小一个字符。 寻找符号链接Unix系统中找符号链接也很简单,在查找命令中一个按文件类型查找的选项。查找符号链接的符号为"l" $ find . -type l -ls 12763168 0 lrwxrwxrwx 1 shs staff 6 Jan 27 2013 ./hlinks/5 -> 5beers 12763423 0 lrwxrwxrwx 1 shs staff 4 Nov 23 2013 ./projects/tmp -> /tmp 查找不指向当前文件的符号链接Unix系统可以创建不指向当前文件的符号链接,创建后删除原文件也是可以的。也可以创建多个符号链接。可以用查找命令和Perl命令追踪他。 find . -type l -print | perl -nle '-e || print'; 确定体系结构(32或64位)使用以下命令: $ arch i686 该命令在 Linux 下也能用。当我在Solaris下使用时,得到答案"sun4"。 颠倒字符rev命令一次性完全颠倒字符,你可以将文本改成这样: $ echo "dlroW ,olleH" | rev Hello, World 也可以写文件名,然后完全颠倒。 $ rev strings yad tsal eht si sihT raf suht efil ruoy fo cigoL .rM 计算文字出现次数我们要考虑几个问题,一个词可能在另一个词中出现,比如"the"是"there"的一部分;一个词也可能在一行里多次出现。我们怎么计算呢?使用【grep -c "word" filename 】命令,他也是和【grep word filename】做差不多的事。他只会告诉你字在每行出现的次数,而不是全部出现的次数,我们可以看看下面的代码: $ cat words the the the the the then there they $ grep -c the words 1 另一种选择,你可以这样做: #!/bin/bash count=0 look4=$1 file=$2 for word in `cat $file` do if [ $word == "$look4" ]; then ((count++)) fi done echo $count 在这个脚本中,如果匹配我们所搜索的,for循环可以让我们看到每个字和增量数。不过该脚本不一定通用。 用一个词替换另一个词完成这个工作,我使用以下命令: sed s/this/that/g filename 无论命令变得多复杂,你都可以在this,that间变换。我们来一个相对复杂的例子。使用 \b标记,确保将 "the" 变为 "why"。 $ cat words the the the the the then there they $ sed -e 's/\bthe\b/why/g' words why why why why why then there they 看到了吗"the"无论在多长的句子里都没变。 如果你想改变"The" 或者 "the",你可以使用下面的命令: $ sed -e 's/\bthe\b/why/g' words The why why why why then there they $ sed -e 's/\bthe\b/why/gi' words why why why why why then there they 从subshell标记可用变量如果不导出设置的shell,Subshells是不会认变量的。 $ cat showme #!/bin/bash echo $something $ something="well done" $ ./showme $ export something $ ./showme well done |