来源Leetcode第195题第10行
给定一个文本文件 file.txt,请只打印这个文件中的第十行。
三种解法
1 | tail -n +10 file.txt | head -n 1 |
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 | awk -F : '{print $1}' passwd ###指定分隔符为: ,输出第一列 |