Nameless Site

But one day, you will stand before its decrepit gate,without really knowing why.

0%

第十行

来源Leetcode第195题第10行

给定一个文本文件 file.txt,请只打印这个文件中的第十行。

三种解法

1
2
3
tail -n +10 file.txt | head -n 1
sed -n '10p' file.txt
awk 'NR==10 {print $0}' file.txt

tail命令和head命令

tail命令显示最后一组文件行。默认情况下,它显示文件的最后10行,但是也是使用命令行参数更改数字,使用tail —h查看命令行参数,截图如下:

如果K前有+,则表示显示除开头K行外所有行

head命令显示开头的一组文件行。默认情况下,它显示文件的前10行。通过head —h命令查看参数截图:

sed

说明
1.从文件中读取数据,StreamEDitor流(行)编辑器,逐行处理文本;
Sed 是一个脚本型的编译器,是非交互式的编辑器
2.模式空间(将一行数据加载到内存,进行处理),默认不编辑源文件,仅对模式空间中的数据处理,将处理的数据输出到屏幕

用法:
    一般用法:
    sed [-neri] ‘指令’ file…
    sed -f scriptsfile file…
选项:
    -n 安静模式,只有经过Sed处理的行才显示出来,其他不显示
    -e 表示直接在命令行模式上进行Sed操作(默认选项);
     进行多项编辑,即对输入行应用多条sed命令时使用
    -f 将Sed的操作写在一个文件里,用的时候“-f filename”就可以按照内容进行Sed操作
    -r 使Sed支持扩展正则表达式(预设支持基础正则表达式)
    -i 直接修改读取的文件内容,而不是输出到终端
    sed 编辑指令的格式如下 :
[address1[,address2]]function[argument]
    ==addres (指定需要操作的行)==
    1. n1,n2 例:1,100 表示1至100行
        n1行开始,n2行结束
        处理n1行开始到n2行结束的数据
        $符号表示文件最后一行
    2. /RegExp/
        匹配正则表达式
        处理正则表达式匹配的行的数据
    3. /pattern1/,/pattern2/
        pattern1匹配到为行开始
        pattern2匹配到为行结束
        处理pattern1,到pattern2之间所有行数据
    4. n
        指定第n行的
        处理指定第n行的数据
    5. n1,+n
        n1 为行开始
        +n 开始行向后n行
        处理行开始到向后n行的数据
    ==function(可对数据处理的动作(sed内定函数))==
    d 删除符合条件的行
    D 删除模板块的第一行
    h 拷贝模板块的内容到内存中的缓冲区
    H 追加模板块的内容到内存中的缓冲区
    g 获得内存缓冲区的内容,并替代当前模板块中的文本
    G 获得内存缓冲区的内容,并追加到当前模板块文本的后面
    p 显示符合条件的行
    P (大写) 打印模板块的第一行
    q 退出Sed
    l 列表不能打印字符的清单
    n 读取下一个输入行,用下一个命令处理新的行而不是用第一个命令。
    N 追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码
    a \”string” 在指定的行后面追加新行,内容为”string”
    i \”string” 在指定的行前面插入新行,内容为”string”
    c \”string” 将处理的数据行,取代内容为”string”
    r file 将指定文件的内容天骄到符合条件的行后
    w file 将指定范围内的内容另存至指定的文件中
    W file (大写)写并追加模板块的第一行到file末尾。
    s/pattern/string/修饰符 查找并替换,默认只替换每行第一次被模式匹配到的字符串
        修饰符:
            g 表示行内全面替换。
            p 表示打印行。
            w 表示把行写入一个文件。
            x 表示互换模板块中的文本和缓冲区中的文本。
            y 表示把一个字符翻译为另外的字符(但是不用于正则表达式)
            \1 子串匹配标记
            & 已匹配字符串标记
            i 忽略大小写
        特别说明: s///,s###,s@@@都可以,当所使用的分割符号与内容中显示
        的相同时,需使用转义字符转义 ,\1,\2:成组匹配,\1表示匹配第一
        个‘(’,\2表示匹配第二个‘(’
    b lable 分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾
    t label if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾
    T label 错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾
    ! 表示后面的命令对所有没有被选定的行发生作用。
    = 打印当前行号码。
    # 把注释扩展到下一个换行符以前

awk操作

awk [-F|-f] ‘BEGIN{}{command1; command2} END{}’ file
[-F|-f] 大参数,-F指定分隔符,-f调用脚本
‘ ‘ 引用代码块
// 匹配代码块,可以是字符串或正则表达式
{} 命令代码块,包含一条或多条命令
; 多条命令使用分号分隔


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
awk -F : '{print $1}' passwd  ###指定分隔符为: ,输出第一列
awk -F : 'BEGIN{print 'hello'}{print $2}' passwd ###指定分隔符为:,在输出前加上hello,输出第二列【hello在第一行】
awk -F : 'BEGIN{n=1}{print $2,n}' passwd ###指定分隔符为:,在输出的第二列每一行后面都输出n的值1
awk -F : 'BEGIN{n=1}{print $2,n++}' passwd ###n的值每一行会加1
awk -F : 'BEGIN{n=1}{print n++,$1}' passwd ###相当于序号
awk -F : 'BEGIN{n=1}{print n++,$1}END{print "over"}' passwd ###指定分隔符为:,在第一列每一行开头加上n的值,n每行+1,在最后一行输出over
awk -F : 'BEGIN{n=1}{print n++,$1}END{print NR}' passwd ###指定分隔符为:,在第一列每一行开头加上n的值,n每行+1,最后一行输出有多少行
awk -F : 'BEGIN{n=1}{print n++,$1}END{print NF}' passwd ###指定分隔符为:,在第一列每一行开头加上n的值,n每行+1,最后一行输出有多少列
awk '/bash/{print}' passwd ###输出包含bash的内容
awk -F : '/bash/{print $1}' passwd ###输出包含bash的第一列
awk -F : 'NR==3{print $1}' passwd ###输出第三行第一列
awk -F : 'NR>=4&&NR<=6{print}' passwd ###输出4-6行
awk -F : 'NR==4||NR==6{PRINT}' passwd ###输出第四行和第六行
awk 'BEGIN{a=34;print a+12}' ###得到a的值46
awk '/^[^a-d]/{print}' passwd ###输出除了以a-d开头的
awk '/^r|bash$/{print}' passwd ###输出以r开头,或许以bash结尾的
awk '/^r/&&/bash$/{print}' passwd ###并且
awk -F : '$6~/bin$/{print}' passwd ###以:为分隔符,输出第六列以bin结尾的
awk -F : '$6!~/\<bin$/{print}' passwd ###输出第六列不是以bin结尾且bin前面没有内容的【非贪婪模式】
awk -F : 'BEGIN={N=0}$6!~/^\/home/&&$7~/bash$/{print $1;N++}END{print N}' /etc/passwd ###并统计个数