8 releases

0.1.7 Jul 4, 2023
0.1.6 Apr 24, 2023
0.0.1 Apr 4, 2023

#272 in Algorithms

Download history 2493/week @ 2024-09-11 2059/week @ 2024-09-18 1713/week @ 2024-09-25 1693/week @ 2024-10-02 1638/week @ 2024-10-09 3640/week @ 2024-10-16 3760/week @ 2024-10-23 3646/week @ 2024-10-30 3325/week @ 2024-11-06 3548/week @ 2024-11-13 3890/week @ 2024-11-20 4527/week @ 2024-11-27 4831/week @ 2024-12-04 4550/week @ 2024-12-11 3592/week @ 2024-12-18 2321/week @ 2024-12-25

16,185 downloads per month

MIT/Apache

43KB
765 lines

IBAN

Crates.io Docs Coverage Status Licensed

This is a crate for working with International Bank Account Numbers (IBANs).

An IBAN is an international standard for identifying bank accounts. It consists of a country code, two check digits, and a Basic Bank Account Number (BBAN) that includes a bank identifier, a branch identifier, and a checksum (if applicable).

This crate provides a simple implementation of IBANs. You can construct an IBAN using a string, and then query it for its country code, and check digits. You can also obtain spaced or electronic formatting using the Display, Debug, Deref, or AsRef implementations.

This crate also provides a Bban struct that represents the BBAN portion of an IBAN. You can construct a BBAN using the Iban::bban function, and then query it for it's bank identifier, branch identifier, or checksum.

Usage

Add library as a dependency to Cargo.toml.

...
[dependencies]
iban = "0.1"
...

Construct a Iban type by using str::parse, FromStr::from_str, or Iban::parse.

use iban::{Bban, Iban};
let iban: Iban = "AA110011123Z5678"
    .parse()
    .unwrap_or_else(|err| {
        // This example panics, but you should handle the error cases properly.
        panic!("invalid iban: {err}");
    });

let country_code: &str = iban.country_code();
let bban: Bban = iban.bban();

let bank_identifier: Option<&str> = bban.bank_identifier();

References

Dependencies

~0.4–1MB
~18K SLoC