連想配列を使用したNode.js用簡易集計モジュール
CoffeeScript JavaScript
Switch branches/tags
Nothing to show
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
lib
test テストを1ファイルにまとめた Oct 2, 2013
LICENSE LICENSE差し替え Jun 20, 2013
README.md
example.js
index.js LICENSE差し替え Jun 20, 2013
package.json コンストラクタのオプションにcalcReturnIsKey追加 Oct 2, 2013

README.md

TinyTotalizer - 連想配列を使用したNode.js用簡易集計モジュール

連想配列のキーに該当したらカウントを加算するような簡易集計を行う場合、連想配列ならではの問題点に遭遇します。

  1. キーが大文字小文字含めて完全一致しないといけない
  2. カウントを加算する前にキーが存在するかチェックする必要がある

TinyTotalizerはそういった問題を気にせずに簡易集計をすることを目的として作られたモジュールですが、その他にもランキング表示などの簡易集計を便利に行う機能を含んでいます。

サンプル

sample.js

var TinyTotalizer = require('tiny-totalizer');

var tt = new TinyTotalizer({ fuzzyLevel: 2 });
tt.add('javascript');
tt.add('JavaScript');
tt.add('coffeeScript', 3);
tt.add('coffee script', 2);
tt.sub('JAVASCRIPT');
  ・
  ・
  ・
console.log(tt.ranking({ topN: 10 }));

/* console.log()の出力
[
  { name: 'coffeeScript', count: 5 },
  { name: 'javascript', count: 1 },
    ・
    ・
    ・
]
*/

TinyTotalizerオブジェクトを作成し、そのオブジェクトに対してaddおよびsubメソッドでキーに該当するカウントを加減算し、最後にrankingメソッドで集計結果のランキング配列を取得する流れになっています。

インストール

npm install tiny-totalizer

使用方法

var TinyTotalizer = require('tiny-totalizer');

で、TinyTotalizerモジュールをロードします。ロードした変数TinyTotalizernewでインスタンス化したオブジェクトで集計を行います。

メソッド

コンストラクタ new([options, initialData])

TinyTotalizerオブジェクトを作成します。

第一引数: options (省略可能)

連想配列で指定します。指定できるオプションは以下の通りです。

  • allowMinus (true/false, デフォルト: true)

    減算により、対象キーのカウントが0未満になる事を許可するかどうかの指定です。

    falseにすると、対象キーのカウントから0未満になるような減算を行ってもカウントは0になります。

  • fuzzyLevel (数値, デフォルト: 0)

    キーの一致判定に関しての曖昧さレベルです。数値で指定します。

    • 0: 大文字・小文字も含めて完全に一致するキーのカウントを加減算します。該当するキーがなければ新規にカウント0でキーを作成します。

    • 1: 大文字・小文字の違いを無視した上で一致するキーのカウントを加減算します。キーの形は元から存在する方です。

    • 2: 大文字・小文字の違いと半角スペースの有無を無視した上で一致するキーのカウントを加減算します。

  • calcReturnIsKey (true/false, デフォルト: false)

    addsubメソッドの戻り値はデフォルト(false)ではそのキーの現在のカウント数ですが、このオプションをtrueにすると戻り値が統一後のキー名になります。今加算(減算)したキーがそのまま格納されたのか、既存のどこかのキーに統一化されて格納されたのかを判別したい時に使用します。

  • standardizer (関数)

    上記fuzzyLevelで用意されている以外のキーの文字統一を行いたい場合に、独自の文字統一関数を登録できます。

    引数で受け取った文字列を加工して返す関数を指定します。

      function customStandardizer (s) {
        // キーを比較する時に、比較する側・される側どちらもこの処理を施してから比較を行う。
        // この例では小文字に統一して、半角スペースとハイフンを除去したキーで比較する。
        return s.toLowerCase().replace(/[\s\-]/g, '');
      });
      var tt = new TinyTotalizer({ standardizer: customStandardizer });  // 文字統一関数を独自のものに変更
      tt.add('javascript');
      tt.add('Java-Script'); // 'javascript'と同一とみなされ、'javascript'キーに加算される
    

    standardizerを指定した場合はfuzzyLevelの指定は無視されます。

第二引数: initialData (省略可能)

オブジェクト作成時点でセットする初期集計データです。

{ キー: カウント }の連想配列を指定します。

カウントが数値化できない値(配列やオブジェクト, 数字以外の文字列など)の場合、そのキーは登録されません。

add(key [, count]);

keyのカウントを加算します。countを省略した場合は1を加算します。

負数を指定した場合は減算されます。

countが数値化できない値(配列やオブジェクト, 数字以外の文字列など)の場合、加算も減算も行いません。

sub(key [, count]);

keyのカウントを減算します。countを省略した場合は1を減算します。

負数を指定した場合は加算されます。

countが数値化できない値(配列やオブジェクト, 数字以外の文字列など)の場合、加算も減算も行いません。

ranking([options])

集計オブジェクトで加減算されたキーをランキング化します。

戻り値は{ name: キー名, count: カウント }の配列です。デフォルトではカウントが多い順にソートされた状態で返されます。

引数optionsは連想配列で指定します。指定できるオプションは以下の通りです。

  • asc (true/false, デフォルト: false)

    trueにするとカウントが少ない順にソートしたランキングを返します。

  • border (数値, デフォルト: 制限なし)

    集計結果表示対象とする必要カウントを指定します。このオプションを指定すると、指定した数値以上のカウント数があるキーのみでランキングを作成します。

  • topN (数値, デフォルト: 制限なし)

    何位までのランキングを作成するかの指定です。例えば10を指定すると、TOP10のランキングを返します。

Changelog

0.1.1 (2013-10-02)

  • コンストラクタのオプションにcalcReturnIsKey追加

0.1.0 (2013-03-20)

  • 初版リリース

ライセンス

MIT licenseで配布します。

© 2013 ktty1220