Skip to content

Python package that consumes an IRD Number and returns either True or False depending on whether the IRD Number is valid or not.

License

Notifications You must be signed in to change notification settings

danieldcoded/NZ_IRD_Number_Validator

Repository files navigation

Inland Revenue Department Number Validator

A validator python package for New Zealand tax numbers (IRD)

Getting Started

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.

If you would like to create your own package follow the guide below:

Installing

pip install git+https://github.com/danielcerezodev/NZ_IRD_Number_Validator.git

Usage

from NZ_IRD_Number_Validator import is_valid

ird_number = "123-456-789"

is_ird_number_valid = is_valid(ird_number)

if is_ird_number_valid:
    print(ird_number + " is valid")
else:
    print(ird_number + " is not valid")

How the validation is done

The following steps are performed:

  • Check the valid range
    • If the IRD number is < 10-000-000 or > 150-000-000 then the number is invalid. This step ensures that the IRD number is in the already issued range, or is in the range expected to be issued in the next 10 years.
  • Form the eight digit base number
    • Remove the trailing check digit.
    • If the resulting number is seven digits long, pad to eight digits by adding a leading zero.
  • Calculate the check digit
    • To each of the base number’s eight digits a weight factor is assigned. From left to right these are: 3, 2, 7, 6, 5, 4, 3, 2.
    • Sum together the products of the weight factors and their associated digits.
    • Divide the sum by 11. If the remainder is 0 then the calculated check digit is 0.
    • If the remainder is not 0 then subtract the remainder from 11, giving the calculated check digit.
    • If the calculated check digit is in the range 0 to 9, go to step 5.
    • If the calculated check digit is 10, continue with step 4.
  • Re-calculate the check digit
    • To each of the base number’s eight digits a secondary weight factor is assigned. From left to right these are: 7, 4, 3, 2, 5, 2, 7, 6.
    • Sum together the products of the weight factors and their associated digits.
    • Divide the sum by 11. If the remainder is 0 then the calculated check digit is 0.
    • If the remainder is not 0 then subtract the remainder from 11, giving the 00 calculated check digit.
    • If the calculated check digit is 10, the IRD number is invalid. 5. Compare the check digit :
    • Compare the calculated check digit to the last digit of the original IRD number.
    • If they match, the IRD number is valid.

Built With

Contributing

Pull requests are welcome.

Authors

License

This project is licensed under the GNU License - see the LICENSE.md file for details.

About

Python package that consumes an IRD Number and returns either True or False depending on whether the IRD Number is valid or not.

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages