免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3226 | 回复: 12
打印 上一主题 下一主题

脚本求助(已解决) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-01-23 14:49 |只看该作者 |倒序浏览
有1个文件/var/adm/sudo.log,内容如下:
*
Jan 23 13:38:00 : test : TTY=pts/2 ; PWD=/home/test ; USER=root ;
    COMMAND=/usr/bin/su -
*

我写了这样的script
current_date=`date | awk '{print $2" "$3}'`
egrep "$current_date" /var/adm/sudo.log

出来的内容是
Jan 23 13:38:00 : test : TTY=pts/2 ; PWD=/home/test ; USER=root ;

我想print出egrep出来的那行和紧跟的后面那行
Jan 23 13:38:00 : test : TTY=pts/2 ; PWD=/home/test ; USER=root ;
    COMMAND=/usr/bin/su -


请问要怎么做?

[ 本帖最后由 tlaoya 于 2008-1-23 15:43 编辑 ]

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
2 [报告]
发表于 2008-01-23 14:53 |只看该作者
字符串查找为什么用egrep?
试试:
grep -A1 "$current_date" /var/adm/sudo.log

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
3 [报告]
发表于 2008-01-23 14:53 |只看该作者
grep -A1

论坛徽章:
0
4 [报告]
发表于 2008-01-23 15:00 |只看该作者
这么快就有回复,感谢。不过solaris 10碰到问题
root@asiadsib1:/var/tmp# grep -A1
grep: illegal option -- A
grep: illegal option -- 1
Usage: grep -hblcnsviw pattern file . . .

论坛徽章:
0
5 [报告]
发表于 2008-01-23 15:13 |只看该作者
那试试sed呢

sed -n "/$current_date/{N;p}" /var/adm/sudo.log

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
6 [报告]
发表于 2008-01-23 15:13 |只看该作者
原帖由 tlaoya 于 2008-1-23 15:00 发表
这么快就有回复,感谢。不过solaris 10碰到问题
root@asiadsib1:/var/tmp# grep -A1
grep: illegal option -- A
grep: illegal option -- 1
Usage: grep -hblcnsviw pattern file . . .


sed -n "/$current_date/{N;p;}"

论坛徽章:
0
7 [报告]
发表于 2008-01-23 15:40 |只看该作者
原帖由 davistar 于 2008-1-23 15:13 发表
那试试sed呢

sed -n "/$current_date/{N;p}" /var/adm/sudo.log



root@asiadsib2:/var/tmp# vi test.ksh
"test.ksh" 3 lines, 86 characters
#!/bin/ksh
current_date=`date | awk '{print $2" "$3}'`
sed -n "/$current_date/{N;p}" /var/adm/sudo.log

root@asiadsib2:/var/tmp# sh test.ksh
sed: command garbled: /Jan 23/{N;p}

也是不可以

论坛徽章:
0
8 [报告]
发表于 2008-01-23 15:42 |只看该作者
Sorry,没注意到ly5066113 的
sed -n "/$current_date/{N;p;}"

root@asiadsib2:/var/tmp# sh test.ksh
Jan 23 13:40:41 : test : TTY=pts/2 ; PWD=/asiadsib2/seamnt1/home/test ;
    USER=root ; COMMAND=/usr/bin/su -


多谢各位帮忙

论坛徽章:
0
9 [报告]
发表于 2008-01-23 15:56 |只看该作者
加不加最后一个分号 差距界么大

论坛徽章:
0
10 [报告]
发表于 2008-01-23 18:35 |只看该作者
原帖由 tlaoya 于 2008-1-23 15:42 发表
Sorry,没注意到ly5066113 的
sed -n "/$current_date/{N;p;}"

root@asiadsib2:/var/tmp# sh test.ksh
Jan 23 13:40:41 : test : TTY=pts/2 ; PWD=/asiadsib2/seamnt1/home/test ;
    USER=root ; COMMAN ...


为什么我在Bourne shell的环境里
没有结果显示出来啊
是不是Bourne shell不能使用带有变量的这样的sed的写法啊
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP