Giter Club home page Giter Club logo

felica-look's Introduction

felica-look

別ソフトウェアで出力した FeliCaカードのダンプ出力を解析して意味のわかる形式で表示します

対応カード

  • Suica互換の交通系カード(利用履歴のみ、駅データは入っていません)
  • Edy
  • RapiCa(鹿児島県の共通乗車IC)
  • nice・pass!カード(遠州鉄道)

対応フォーマット

インストール

  1. Releases からダウンロード
  2. zipファイルを解凍
  3. 実行ファイルをターミナルで実行
    • 直接ファイルを指定して実行
    • 実行パスを設定
    • 実行パスのあるディレクトリにシンボリックリンクを作成(おすすめ)

使い方

$ felica-look ファイル                # フォーマット解析して情報を表示
$ felica-look -e ファイル             # [利用履歴(元データ)] も表示
$ felica-look -x ファイル             # 元データの16進表示もいっしょに表示します
$ felica-look -d [-json] ファイル     # 内部形式に変換したデータをダンプ表示(デバッグ用)

パイプライン(FeliCaカードを読んですぐに表示する)

$ felica_dump | felica-look

YAML

表示用の変換テーブルを YAML形式で持ちます

  • 駅名・停留所の名前はここで追加できます

YAMLファイルの検索ディレクトリ

  1. カレントディレクトリ
  2. 実行ファイルあるディレクトリ(シンボリックリンクを辿って実行ファイルのあるディレクトリを探します)
  3. 実行ファイルあるディレクトリのカードに対応するサブディレクトリ(例:suica.ymlの場合はsuica/suica.yml

ビルド

インストールする場合

$ go get github.com/gnue/felica-look
  • $GOPATH/bin にバイナリがインストールされます

ソースコードからビルドする場合

$ git clone https://github.com/gnue/felica-look
$ cd felica-look
$ go build

注:あらかじめ Go言語をインストールしておく必要があります

$ brew install go

FAQ

  1. なぜ Go言語で開発したのですか?
    • 環境に依存せず配布バイナリのみで使えるようできる
    • また、マルチプラットフォームのバイナリも容易に作成できる
    • C言語のコードを容易に組込める
    • 単に Go言語を使ってみたかったから(初プログラム)
  2. なぜ C言語がまざっているのですか?
    • 他ソフトウェアと共通化をはかるため
    • 実際に suica.h, edy.h は PasoriKit からの流用
    • rapica.h は PasoriKit に組込み予定
    • たぶん Go言語だけで書いたほうがシンプルになるのかもしれないけど、同じ構造体定義やロジックをC言語とGo言語で毎回書き直しはしたくないので
  3. Suicaの駅名が suica.yml に登録されていないのはどうでしてですか?
  4. カードリーダーからFeliCaカードのデータを直接読込まないのですか?
    • パイプラインを使えばそれに近いことが可能です
    • 他のライブラリや環境依存にはしたくないのでカードリーダーからの直接読込みを行う予定はありません
  5. 表示結果をもっとわかりやすくしたい
    • もともとが FeliCaカードのフォーマット確認を目的にしています
    • 目的がずれてしまうので本プログラム内で必要以上の表示整形は行いません
    • さらなる表示のためには機能追加を予定している LTSV/JSON出力を利用し別プログラムで行うのがいいでしょう
      • 例:JSON出力を使ってWebアプリでブラウザ表示
      • 例:LTSV出力を使って fluentd で利用履歴の蓄積

TODO

  • JSON出力(現在はダンプデータのみ対応)
  • LTSV出力(利用履歴のみ)
  • その他カードの対応

felica-look's People

Contributors

gnue avatar

Stargazers

zonepotage avatar griffin-stewie avatar

Watchers

 avatar James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.