テキスト処理を学ぶべき理由
コードに限らず、テキストは常に扱う対象になります。
コードを書くことには熱心でもテキスト処理を学ぶことに熱心ではない方は結構います。
しかし、テキストはコードと同様に学ぶべき対象なのです。その理由を2点説明します。
1. ルーチンワークからプログラミングへ
ログやデータの解析はルーチンワークではありません。
テキストとしてのデータは人間が読める対象である場合が殆どでしょう。
人間が読めるデータですから、一行ずつ直接データを読み、必要な作業を手で行うことはできます。
しかしこれはひどく退屈なルーチンワークにしかなりません。
テキストをプログラミングの対象として扱う方法や技術を学ぶことで
ルーチンワークを排して楽しいプログラミングをすることが出来ます。
2. プログラマの生産性を向上させる
テキスト処理は手作業でやろうとすると思う以上に時間がかかるものです。
プロジェクト全体のコメントのフォーマットを変更する、などは手作業でやることも出来ますが、
手作業だと変更し忘れるファイルがあったりすることは良くあります。
チェックの時間も含めると手作業による効率はあまりよくないことが分かると思います。
以下で紹介する技術は全て一朝一夕で出来るものではありません。むしろ
一生かけて学ぶものの一つを紹介することを目的に記事を書きました。
しかし前述のようにこれらの技術は一生使うに能う理由があります。
是非触って見てください。
1. テキストエディタ
当然ですがテキストエディタを扱うということは最も重要なことになるでしょう。
しかし、テキストエディタは熟練度による生産性の差が明瞭に表れるものの一つでしょう。
ViやEmacsなどのエディタは単純に文字を一つずつ打つという機能だけではありません。
文字列置換や様々なユーティリティがあり、また様々なショートカットキーがあります。
これらの機能は直感的ではない所が結構あったりします。それはこれらのキーが熟練者に最適であるようにデザインされているからであり、入門しやすいようになっている訳ではないからです。
この点が多くのIDEや商業ソフトウェアのUIとの違いでしょう。
入門が簡単なエディタと、熟練者にとって最適なエディタ。
一生プログラミングを続けるなら、どちらを選ぶべきかは自明でしょう。
2. awk
テキスト処理と言えばawkです。
awkはテキスト処理だけの為に開発されたという男らしいプログラミング言語です。manページも3ページしかありません。しかしテキスト処理という点に関しては不足のない言語です。
awkの基本的なアルゴリズムはパターンマッチングです。
入力テキストを行毎に読み込み、その行がパターンに合致していたら処理を行う。
これを最終行に行くまで繰り返す。
非常に簡潔で明解な言語です。文法も簡潔なので殆どの処理は一行(one liner)で済ませることが出来ます。
awk '/error/{print $1, $2}'
とすればerrorの文字列を含む行の1番目、2番目の語を出力するという処理になります。
awkは特にデータの解析に有用です。
gnuplotなどにデータを流し込む前の前処理を行ったり、統計値を取ったり、 データからデータを取り出すような処理に対して威力を発揮します。
参照リンク
The GNU Awk User's Guide
フルドキュメント。非常に詳解なので困ったらこれを見ればいいでしょう。
AWK入門(ドットインストール)
awkの入門の為ならこちらをお勧めします。awkのしっかりとした言語であるという側面と、簡単に記述できるという側面の両方を見ることが出来ます。
3. grep
grepは文字列検索の為のコマンドです。
作業のチェックやログの解析などに用いられます。
例えばプログラム中に埋め込んだTODO:をすべて読み込むには
grep -n TODO: main.cpp
とすれば
118: // TODO: Array of dynamic sized objects.
124: // TODO: temporal buffer to store nodes from income buffer.
147: // TODO: Get nodes from income buffer and put it into open list.
170: // TODO: minf(int f):
221: // TODO: incumbent solution.
223: // TODO: For some reason, sometimes pops broken node.
245: // TODO: need it to be atomic.
277: // TODO: Push items to thread safe income buffer.
289: // TODO: trylock
372: // TODO: Time to printing these texts are included in the walltime.
377: // TODO: pack to a method
のように出力され、進捗状況が概観するのに使えます。
awkと比較すると、grepは出力を編集するためのものではなく、
インタラクティブに、テキストがどうなっているのかを把握するために使いやすいように思います。
grepによるパターンの検索(Oracle)
4. Ruby or Python
やや大規模なテキスト処理を行う場合、シェルスクリプトやawkでは表現力が足りなかったり、あるいは読みやすいコードにならない場合があります。しかしテキストデータに対してC++やJavaで書くのはオーバーキルな場合が多いです。
RubyやPythonのような言語を理解しているとこういうちょっとしたプログラムを実装するのにも役に立ちます。
先に述べましたように、これらの技術は小手先技ではなく、一朝一夕に得られるものではありません。しかしスケールアップしていくものです。
一生使える技術を学びましょう。