我正在打开一个通过ARGV在运行时获取的文件:
File.open(ARGV[0]) do |f| f.each_line do |line|
if line.match(/(strcpy)/i) puts "[!] strcpy does not check for buffer overflows when copying to destination." puts "[!] Consider using strncpy or strlcpy (warning,strncpy is easily misused)." puts " #{line}" end
我想知道如何在(ARGV [0])文件中打印出匹配行的行号.
使用print __LINE__显示Ruby脚本中的行号.我已尝试使用#{line}的不同字符串插值打印__LINE__的许多不同变体但没有成功.有没有办法可以打印出文件中的行号?
解决方法
当Ruby的IO类打开一个文件时,它会设置$.全局变量为0.对于读取的每一行,变量都会递增.所以,要知道读取了哪一行,只需使用$..
查看English模块中的$.或$INPUT_LINE_NUMBER.
我们也可以使用属于IO类的lineno方法.我觉得有点复杂,因为我们需要一个IO流对象来解决这个问题,而$.永远都会工作.
我会更简单地编写循环:
File.foreach(ARGV[0]) do |line|
需要考虑的是,如果您使用的是* nix系统,则可以使用操作系统内置的grep或fgrep工具来大大加快处理速度. “grep”系列应用程序针对您的需求进行了高度优化,并且可以查找所有实例,只有第一个,可以使用正则表达式或固定字符串,并且可以使用Ruby的%x或反引号运算符轻松调用.
puts `grep -inm1 abacus /usr/share/dict/words`
哪个输出:
34:abacus
-inm1表示“忽略字符大小写”,“输出行号”,“第一次出现后停止”