linux查看某个时间段的日志(sed -n)

有时候找出某个时间段的日志,如2023-12-09 20:11:00 到 2023-12-09 20:15:59
用grep不太方便直接过滤出来,能够使用sed根据时间去查

sed -n ‘/开始时间日期/,/结束时间日期/p’ 日志文件名称

sed -n '/2023-12-09 20:11:00/,/2023-12-09 20:15:59/p'   aaaa.log

sed 也可以结合 grep 使用,比如我查询上面日志某个时间段的带有 ccccc 的日志行

sed -n '/2023-12-09 20:11:00/,/2023-12-09 20:15:59/p'   aaaa.log  | grep "ccccc"

sed的选项、命令、替换标记
命令格式
sed的命令格式:sed [options] ‘command’ file(s);
sed的脚本格式:sed [options] -f scriptfile file(s);
options:选项

 -e :直接在命令行模式上进行sed动作编辑,此为默认选项;
 
 -f :将sed的动作写在一个文件内,用–f filename 执行filename内的sed动作;
 
 -i :直接修改文件内容;
 
 -n :只打印模式匹配的行;
 
 -r :支持扩展表达式;
 
 -h或--help:显示帮助;
 
 -V或--version:显示版本信息。

sed常用命令

 a\ 在当前行下面插入文本;
 
 i\ 在当前行上面插入文本;
 
 c\ 把选定的行改为新的文本;
 
 d 删除,删除选择的行;
 
 D 删除模板块的第一行;
 
 s 替换指定字符;
 
 h 拷贝模板块的内容到内存中的缓冲区;
 
 H 追加模板块的内容到内存中的缓冲区;
 
 g 获得内存缓冲区的内容,并替代当前模板块中的文本;
 
 G 获得内存缓冲区的内容,并追加到当前模板块文本的后面;
 
 l 列表不能打印字符的清单;
 
 n 读取下一个输入行,用下一个命令处理新的行而不是用第一个命令;
 
 N 追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码;
 
 p 打印模板块的行。 P(大写) 打印模板块的第一行;
 
 q 退出Sed;
 
 b lable 分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾;
 
 r file 从file中读行;
 
 t label if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾;
 
 T label 错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾;
 
 w file 写并追加模板块到file末尾;
 
 W file 写并追加模板块的第一行到file末尾;
 
 ! 表示后面的命令对所有没有被选定的行发生作用;
 
 = 打印当前行号;
 
 # 把注释扩展到下一个换行符以前;

sed替换标记

 g 表示行内全面替换;
 
 p 表示打印行;
 
 w 表示把行写入一个文件;
 
 x 表示互换模板块中的文本和缓冲区中的文本;
 
 y 表示把一个字符翻译为另外的字符(但是不用于正则表达式);
 
 \1 子串匹配标记;
 
 & 已匹配字符串标记;

sed用户实例

替换操作:s命令
替换文本中的字符串:

 sed 's/book/books/' file

-n选项和p命令一起使用表示只打印那些发生替换的行:

 sed -n 's/test/TEST/p' file

选定行的范围:,(逗号)
所有在模板test和check所确定的范围内的行都被打印:

sed -n '/test/,/check/p' file

打印从第5行开始到第一个包含以test开始的行之间的所有行:

sed -n '5,/^test/p' file
  • 9
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值