Skip to main content

An implementation of UK income tax Pay-As-You-Earn calculations

Project description

PAYE

Implementation of UK Income Tax Pay-As-You-Earn algorithms

In the UK, many employees and pensioners pay income tax in weekly or monthly installments as a deduction on their payslip under a system known as Pay-As-You-Earn or PAYE.

In this system, His/Her Majesty's Revenue and Customs (HMRC) gives the employer/pension provider a "Tax Code" which they use to calculate how much income tax to deduct.

This package implements the algorithms for calculating the income tax due as defined by HMRC in their "SPECIFICATION FOR PAYE TAX TABLE ROUTINES" from version 18, dated March 2020 onwards.

HMRC Constants

The algorithms use a set of constants that are dependent on tax year and defined in the Specification.

This package reads the constants from a TOML file 'hmrc.toml' which needs to be updated for each new tax year.

Exported Objects

  1. the TaxCode class
  2. the Payslip class
  3. utility function str_to_decimal

Usage

Weekly vs Monthly pay is selected by the environment variable PAYE_PERIOD: PAYE_PERIOD=weekly or PAYE_PERIOD=monthly

if unset, monthly is assumed

The inputs are:

  1. The pay date
  2. Your basic pay for the week / month
  3. Your tax code for the week / month (as given by HMRC via a letter or your Personal Tax Account on gov.uk)
  4. Any pay adjustments for the week / month (e.g. bonus)
  5. Any payrolled benefits in kind ... and for cumulative tax codes;
  6. The tax period number
  7. Your total gross pay for the tax year including this week / month
  8. The income tax you've paid so far this tax year, NOT including this week/month

Use these to create an instance of the Payslip class

The income tax for this week / month is provided by the income tax property of the payslip.

For example:

import paye
from decimal import Decimal
from fiscalyear import FiscalDateTime

payslip = paye.Payslip(
  pay_date = FiscalDateTime(2026, 4, 30),
  basic_pay=Decimal('1156.25'),
  code=paye.TaxCode('1257L'),
  pay_to_date=Decimal('1156.25'),
  tax_to_date_non_inclusive=Decimal('0.00')
)
print(f"Income tax due this period = {payslip.income_tax}")

Testing

This module is validated against the test cases provided by HMRC

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

paye-0.7.0.tar.gz (92.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

paye-0.7.0-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

Details for the file paye-0.7.0.tar.gz.

File metadata

  • Download URL: paye-0.7.0.tar.gz
  • Upload date:
  • Size: 92.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.5 cpython/3.14.4 HTTPX/0.28.1

File hashes

Hashes for paye-0.7.0.tar.gz
Algorithm Hash digest
SHA256 da056bdbed95d3eb52169a785c70406ccd56212840daee9ea95cecaeb9761f92
MD5 9c41e72a90050cb9414d65a7b4b5d677
BLAKE2b-256 eb0cc092fd63156e72117356903cbac3c77f3216c623f251ea9a2e006a72e961

See more details on using hashes here.

File details

Details for the file paye-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: paye-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 9.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.5 cpython/3.14.4 HTTPX/0.28.1

File hashes

Hashes for paye-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5b6048aa1f158442a51db209fca819d1a0b4745ac3441a167a73b3cf11c5b62e
MD5 73f8643609f2f56e57213e3528402c24
BLAKE2b-256 e337358ea3ff06df9ced65d907c5c8444faf2a4afbcbadfb95254b53f6d22e31

See more details on using hashes here.

Supported by

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