免费注册 查看新帖 |

Chinaunix

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

我这样统计文件的相同行为什么不行,谁能帮我 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-06-10 11:33 |只看该作者 |倒序浏览
我要统计文件符合要求的行数
文件内容如下
DOUT[0]
DOUT[1]
DOUT[2]
DOUT[3]
DOUT[4]
.......
......

  1. ln=DOUT[0]
  2. lnnum=`grep -c "^$ln\>" filename`
  3. echo $lnnum
复制代码

为什么显示为0啊,应该是有一个匹配啊。。

谢谢高手赐教

论坛徽章:
0
2 [报告]
发表于 2004-06-10 11:49 |只看该作者

我这样统计文件的相同行为什么不行,谁能帮我

因为”[“和"]"及”\>“发生错误,可以这样查:
lnnum=`grep -c "^DOUT\[0\]" filename`

论坛徽章:
0
3 [报告]
发表于 2004-06-10 12:36 |只看该作者

我这样统计文件的相同行为什么不行,谁能帮我

[quote]原帖由 "随风漂"]ename`[/quote 发表:


有没有什么通用的写法。
其实我每次要统计的行的内容都不相同,我会把要用的内容赋给变量ln
但是只有当碰到含有"[]"时,匹配会出错

论坛徽章:
0
4 [报告]
发表于 2004-06-10 13:02 |只看该作者

我这样统计文件的相同行为什么不行,谁能帮我

文件test2内容如下:

temp=$1;
ln=${temp/[/\\[}
ln=${ln/]/\\]}
echo $ln
lnnum=`grep -c "^$ln" $2`
echo $lnnum

这样就可完成通用的匹配:

test2 DOUT[0] filename

论坛徽章:
0
5 [报告]
发表于 2004-06-10 13:29 |只看该作者

我这样统计文件的相同行为什么不行,谁能帮我

可否解释一下。
我好像不行。提示Bad Substitution

论坛徽章:
0
6 [报告]
发表于 2004-06-10 14:04 |只看该作者

我这样统计文件的相同行为什么不行,谁能帮我

这样试试:
ln="DOUT\\[0\\]"
lnnum=`grep -c "$ln" filename`

论坛徽章:
0
7 [报告]
发表于 2004-06-10 14:10 |只看该作者

我这样统计文件的相同行为什么不行,谁能帮我

统计文件中相同的行直接用uniq -c就可以的呀@_@
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP