236
212

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

LivesenseAdvent Calendar 2015

Day 4

The Silver Searcher のススメ

Last updated at Posted at 2015-12-03

What is The Silver Searcher

The Silver Searcher

ファイルに対して再帰的に文字列検索を行なうコマンドです。要はスゴイ grep です。Silver だから ag というコマンド名という。

Why The Silver Searcher

  • とても速い。

    • Pthreads を使用し並列処理を行なう。
  • .git や .svn を検索除外してくれる。

    • .gitignore の内容も除外してくれる。
      • ag のみで除外したい場合は .agignore というファイルも利用可能。
  • 検索対象ファイルのファイルタイプをオプション指定できる。

    • --ruby と指定すると (.rb .rhtml .rjs .rxml .erb .rake .spec) が対象になる。

インストール

OS X

Homebrew で

$ brew install the_silver_searcher

Debian系

$ sudo apt install silversearcher-ag

RHEL系

$ sudo rpm -Uvh http://download.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-5.noarch.rpm
$ sudo yum install the_silver_searcher

Fedora 22以降

$ sudo dnf install the_silver_searcher

使い方

カレントディレクトリ以下を検索

$ ag pthread

特定ディレクトリ以下を検索

$ ag pthread /usr/src

圧縮ファイルも検索

$ ag -z pthread

対応しているファイルフォーマットは以下の表の通り。xz は対応済みだが、bzip2 は非対応な点に注意。

フォーマット 対応状況
gzip o
bzip2 x
xz o
UNIX Compress x
ZIP x

ちなみに各種ツールを process fork して呼び出してるわけではなく、ag 自体で decompress しています。速度へのこだわりがすごい。

ファイル/ディレクトリ名のパターンを指定して検索

$ ag -G '\.(c|h)' pthread

パターンは正規表現で指定するため、shell の glob っぽく *.c と記載すると動かないので注意。

ファイルタイプを指定して検索

$ ag --cc pthread

一般的によく使われるであろう言語については下記の通り対応済み。

FILE TYPE suffix
--cc .c .h .xs
--cpp .cpp .cc .C .cxx .m .hpp .hh .h .H .hxx
--html .htm .html .shtml .xhtml
--java .java .properties
--js .js .jsx
--perl .pl .pm .pm6 .pod .t
--php .php .phpt .php3 .php4 .php5 .phtml
--python .py
--ruby .rb .rhtml .rjs .rxml .erb .rake .spec
--shell .sh .bash .csh .tcsh .ksh .zsh
--xml .xml .dtd .xsl .xslt .ent
--yaml .yaml .yml

他の言語についても対応しているかどうかは下記コマンドで確認可能です。

$ ag --list-file-types

隠しファイルも検索

$ ag --hidden pthread

隠しファイルとは '.' から始まるファイルやディレクトリです。

全ファイルを検索

$ ag -u pthread

.agignore や .gitignore の内容も無視し、上記の隠しファイルも含めて全てのファイルを検索対象とします。

マッチしたファイル名だけ表示

$ ag -l pthread

ちなみに ag -l で検索対象ファイルの全表示になります。

マッチしなかったファイル名だけ表示

$ ag -L pthread

上記の逆ですね。

ファイル名(相対パス含む)に対して検索

$ ag -g pthread

上記の -l はファイル内容にマッチしたファイル名のみ表示。こちらの -g はファイル名にマッチしたら表示。ややこしい。

再帰処理するディレクトリ階層の深さを指定

$ ag --depth 1 pthread
  • 0 を指定すると指定したディレクトリのみ。
  • 1 を指定すると 1階層までディレクトリ再帰処理する。
  • -1 を指定すると無限に再帰処理する。
    • デフォルトは 25。

セパレーターを NULL にして表示

$ ag -0 pthread

詳細は下記応用例で。

応用例

ファイル名が FILE_PATTERN にマッチして、かつ、PATTERN が含まれているファイル名を表示したい

$ ag -l -G FILE_PATTERN PATTERN

-l -g だとダメなので注意。

PATTERN が含まれているファイルに xargs で COMMAND 処理を行なう

$ ag -l -0 PATTERN | xargs -0 COMMAND

ag -0 は find(1) でいうところの -print0 と同等で、ファイル名に空白が含まれていると xargs(1) 側でうまく処理ができないのが理由です。

Atom から使いたいよ

atom-fuzzy-grep を使うと便利。

atom-fuzzy-grep ↑ こんな感じでプロジェクトに含まれるファイル郡から fuzzy 検索できるようになります。 あまりに大量にファイルがあると結果出てくるまでに数秒かかったり結果リストがリアルタイムに更新されたりするけど、慣れれば気にならない予感。

自分の環境(OSX El Capitan + Homebrew + Homebrew Cask)だと ag がみつからないとエラーになってしまうので、設定画面で /usr/local/bin/ag -i --nocolor --nogroup --column を設定して解決。 同様の Issue が Failed to spawn command ag on second window として報告されてますなー。

ちなみに Atom 標準の Find and Replace package の Find in project のように新しいタブを開いて検索結果をリストアップ、という Package はまだない模様。

似たツールはないのかな

ack

ack

高速grepツールの草分け?

perl で書かれているので ag と比較すると若干処理に時間がかかる。というより ag はスピードを追求した ack という出自っぽい。

sift

sift

ag よりも速いし高機能のようだけど、メモリー使用量が結構すごいらしい(未検証)。

highway

highway

ag よりも速い(手元の環境で確かに速かった)上に、EUC-JP や Shift-JIS にも対応していてステキ。

--column オプションがないので、上記の atom-fuzz-grep はうまく動かない模様…。unite.vim だと動くようなのに…。

highway という高速検索ツールを作りました

The Platinum Searcher

The Platinum Searcher

ag 相当の速度で Go で書かれていて、EUC-JP や Shift-JIS にも対応。

Go言語でag(The Silver Searcher)ライクな高速検索ツールをつくった。EUC-JP/Shift-JISも検索できマス。

まとめ

高速grepツールの進化がすごいので、これからも便利になる予感。

Atom の Find in project のような使い勝手で使えるようになるといいなー。そのうち自分で作るかもだけど、そもそも JavaScript 書けないしなー、とか。

236
212
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
236
212

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?