GithubHelp home page GithubHelp logo

mbartok / bank-statements Goto Github PK

View Code? Open in Web Editor NEW

This project forked from jakubzapletal/bank-statements

0.0 2.0 0.0 260 KB

The PHP library to parse bank account statements

License: MIT License

PHP 100.00%

bank-statements's Introduction

Bank Statements

Build Status Coverage Status SensioLabsInsight

Latest Stable Version Total Downloads Latest Unstable Version License

This is a PHP library to parse bank account statements. The purpose of this library is to simplify bank statements processing and usage in your application in more standardized way. The parser result is an instance of: JakubZapletal\Component\BankStatement\Statement\StatementInterface containing detail information about a statement and an array of JakubZapletal\Component\BankStatement\Statement\Transaction\TransactionInterface with further information about transactions.

Supported formats/bank list

  • ABO (*.gpc) [doc]
  • Česká spořitelna (CZ): JakubZapletal\Component\BankStatement\Parser\ABO\CeskaSporitelnaCZParser
  • ČSOB (CZ): JakubZapletal\Component\BankStatement\Parser\ABOParser
  • Fio banka (CZ): JakubZapletal\Component\BankStatement\Parser\ABOParser
  • GE Money Bank (CZ): JakubZapletal\Component\BankStatement\Parser\ABOParser
  • Komerční banka (CZ), alias KM format: JakubZapletal\Component\BankStatement\Parser\ABOParser
  • Raiffeisenbank (CZ): JakubZapletal\Component\BankStatement\Parser\ABOParser
  • XML
  • ČSOB (CZ) [doc]: JakubZapletal\Component\BankStatement\Parser\XML\CSOBCZParser
  • CSV

Installation

Note that Bank Statements is PSR-4 compliant:

Composer

If you don't have Composer install it:

$ curl -s https://getcomposer.org/installer | php

Add jakubzapletal/bank-statements to composer.json:

$ composer require "jakubzapletal/bank-statements:1.0.*@dev"

Usage

Parsing of each format is provided by a class implementing:

JakubZapletal\Component\BankStatement\Parser\ParserInterface

Thanks to the interface we can rely on two main public methods: parseFile and parseContent.

  • parseFile expects as an argument a path to file and then processes the parsing
  • parseContent expects as an argument a string of content and then processes the parsing

Both methods return a class implementing:

JakubZapletal\Component\BankStatement\Statement\StatementInterface

The statement class includes transaction items, which are classes implementing:

JakubZapletal\Component\BankStatement\Statement\Transaction\TransactionInterface

This behaviour ensures the same approach to the parsing and results for all parsers.

All abstract classes and standard classes are easily extendable, allowing implement parsing process of any data.

The basic statement class:

JakubZapletal\Component\BankStatement\Statement\Statement

implements Countable and Iterator, so we can call function count() on it's instances or traverse them using foreach(). Keep in mind that transactions of the statements are used. If you need more functionality in the statement class, I recommend extend this class.

Examples

The parsing:

use JakubZapletal\Component\BankStatement\Parser\ABOParser;

$parser = new ABOParser();

// by path to file
$path = '/path/to/file';
$statement = $parser->parseFile($path);

// by content
$content = 'string of data';
$statement = $parser->parseContent($content);

Manipulation with the statement:

echo count($statement); // echo count of transaction items

foreach ($statement as $transaction) {
    // do something with each transaction
}

echo $statement->getAccountNumber(); // echo an account number of the statement

Contributing

Contributions are welcome! Please see the Contribution Guidelines.

bank-statements's People

Contributors

jakubzapletal avatar

Watchers

James Cloos avatar Matej Bartok 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.