Skip to main content

A simple Django app that provides Indonesian Bank models and fields.

Project description

A Django application that provides Indonesian bank choices for use with forms and a country field for models.

Installation

  1. Run pip install p1-bank

  2. Add 'bank' to INSTALLED_APPS in settings.py

  3. Run python manage.py migrate to create banks models

Bank Model

A model of bank that holds all banks in Indonesia.

Supports long name, short name, bank code, and branch code.

>>> from django.apps import apps
>>> Bank = apps.get_model('bank', 'Bank')
>>> bank = Bank.objects.get(short_name='BANK BCA')
>>> bank.long_name
u'PT. BANK CENTRAL ASIA TBK.'
>>> bank.short_name
u'BANK BCA'
>>> bank.bank_code
u'014'
>>> bank.branch_code
u'0397'
>>> bank.bi_code
u'0140397'

It is possible to get a bank object from bi code:

>>> Bank.objects.get_by_bi_code('0140397')
<Bank: BANK BCA>

or upsert (update or create) from list with header:

>>> Bank.objects.get(bank_code='200')
<Bank: BANK BTN>
>>> bank_list = [
        ['bank_code', 'short_name'],
        ['200', 'BTN']
    ]
>>> Bank.objects.upsert_from_list_with_header(bank_list)
>>> Bank.objects.get(bank_code='200')
<Bank: BTN>

Bank Field

BankField is based on Django’s ForeignKey, a relationship to Bank model.

Consider an Account model using a BankField:

from django.db import models
from p1_bank.fields import BankField

class Account(models.Model):
    name = models.CharField(max_length=100)
    bank = BankField(related_name='accounts')

Any Account instance will have a bank attribute that you can use to identify account’s bank:

>>> bank = Bank.objects.get(short_name='BANK BCA')
>>> account = Account.objects.create(name='Kania', bank=bank)
>>> account.bank
'BANK BCA'
>>> account.bank.code
'014'

Bank Factories

You may use bank factories to support your test (requires factory_boy)

>>> from bank.factories import BankFactory
>>> BankFactory()
<Bank: Bank X00>
>>> BankFactory()
<Bank: Bank X01>
>>> bank301 = BankFactory(bank_code='301')
>>> bank301.bank_code
'301'

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

p1-bank-0.2.37096567.tar.gz (10.2 kB view details)

Uploaded Source

Built Distribution

p1_bank-0.2.37096567-py2-none-any.whl (14.0 kB view details)

Uploaded Python 2

File details

Details for the file p1-bank-0.2.37096567.tar.gz.

File metadata

  • Download URL: p1-bank-0.2.37096567.tar.gz
  • Upload date:
  • Size: 10.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.3.0 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/2.7.15

File hashes

Hashes for p1-bank-0.2.37096567.tar.gz
Algorithm Hash digest
SHA256 2dd6dc5af84032db5a9597fb4e751379acea0caa60bb7bf44b41d1ebbd867ee2
MD5 bb676a07f5dc119d51883b38371c3812
BLAKE2b-256 6bc36302542f8f868f5b6c8652a5a6f65bf42f5a995de46c185d7cfb87c512e6

See more details on using hashes here.

File details

Details for the file p1_bank-0.2.37096567-py2-none-any.whl.

File metadata

  • Download URL: p1_bank-0.2.37096567-py2-none-any.whl
  • Upload date:
  • Size: 14.0 kB
  • Tags: Python 2
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.3.0 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/2.7.15

File hashes

Hashes for p1_bank-0.2.37096567-py2-none-any.whl
Algorithm Hash digest
SHA256 456a87f935904c682d42480f7d91913deab986d8dc5e7f6353b3d3e500b75b45
MD5 f0f4d3989eb8127a43b9ebfb7c20906c
BLAKE2b-256 3098f8a15e82996d88eec0bf4b2153b0e034f8fa95841a4b0563df992fa99a1d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page