Zakat calculator
Project description
Zakat Calculator
A Python calculator for Zakat computation.
Supported Asset Types
- Cash: cash on hand and bank accounts
- Gold & Silver: converted to monetary value using provided prices per gram
- Business assets: inventory and receivables
- Stocks: stocks and investments
- Agricultural produce: irrigated (5% rate) and rain-fed (10% rate) with separate Nisab of 653 kg
- Livestock: camels, cattle, and sheep/goats with detailed schedules
- Recoverable debts: optionally included in zakatable wealth
Supported Rules
- Nisab threshold using lower of gold (85g) or silver (595g) equivalent
- Standard 2.5% rate on cash, gold, silver, business assets, and stocks
- Debt and expense deductions before calculation
- Separate agricultural Nisab (weight-based or monetary approximation)
- Livestock schedules for camels (5+), cattle (30+), and sheep/goats (40+)
Live Market Prices
Built-in MarketPrices class fetches live gold/silver prices, exchange rates, and crypto prices with a fallback chain:
- Primary API
- Backup API
- Hardcoded defaults
Installation
pip install zakat-calculator
Or directly from GitHub:
pip install git+https://github.com/qcri/zakat-calculator.git
Quick Start
from decimal import Decimal
from zakat_calculator import ZakatCalculator
calc = ZakatCalculator(
gold_price_per_gram=Decimal("95.00"),
silver_price_per_gram=Decimal("1.05"),
currency="USD",
)
result = calc.calculate(
cash=Decimal("50000"),
gold_grams=Decimal("100"),
stocks_value=Decimal("25000"),
debts_you_owe=Decimal("5000"),
)
print(f"Nisab threshold: {result.nisab_threshold:.2f} {result.currency}")
print(f"Zakat obligatory: {result.is_zakat_obligatory}")
print(f"Zakat due: {result.zakat_due:.2f} {result.currency}")
Live Market Prices Usage
from zakat_calculator import MarketPrices, ZakatCalculator
from decimal import Decimal
mp = MarketPrices()
gold = mp.get_gold_price_per_gram()
silver = mp.get_silver_price_per_gram()
calc = ZakatCalculator(
gold_price_per_gram=Decimal(str(gold.value)),
silver_price_per_gram=Decimal(str(silver.value)),
)
Livestock Zakat
result = calc.calculate_livestock_zakat(
camels=30,
cattle=45,
sheep_goats=150,
)
for animal_type in ["camels_zakat", "cattle_zakat", "sheep_goat_zakat"]:
info = result[animal_type]
if info["zakat_applicable"]:
print(f"{animal_type}: {info['details']}")
API Reference
ZakatCalculator
ZakatCalculator(
gold_price_per_gram: Decimal, # current gold price per gram in your currency
silver_price_per_gram: Decimal, # current silver price per gram in your currency
currency: str = "USD", # ISO 4217 currency code
)
calculate(...) -> ZakatCalculation
calc.calculate(
cash=Decimal("0"),
gold_grams=Decimal("0"),
silver_grams=Decimal("0"),
business_assets=Decimal("0"),
stocks_value=Decimal("0"),
agricultural_irrigated=Decimal("0"),
agricultural_rainfed=Decimal("0"),
agricultural_produce_kg=Decimal("0"),
debts_you_owe=Decimal("0"),
recoverable_debts=Decimal("0"),
)
All parameters are optional and default to 0. Pass only what applies.
Input parameters (all optional, default 0):
| Parameter | Type | Description |
|---|---|---|
cash |
Decimal |
Cash on hand and bank balances |
gold_grams |
Decimal |
Gold weight in grams |
silver_grams |
Decimal |
Silver weight in grams |
business_assets |
Decimal |
Inventory and trade receivables |
stocks_value |
Decimal |
Market value of stocks and investments |
agricultural_irrigated |
Decimal |
Value of irrigated crops (5% rate) |
agricultural_rainfed |
Decimal |
Value of rain-fed crops (10% rate) |
agricultural_produce_kg |
Decimal |
Produce weight in kg (for Nisab check) |
debts_you_owe |
Decimal |
Liabilities deducted from zakatable wealth |
recoverable_debts |
Decimal |
Money owed to you (optional inclusion) |
Returned ZakatCalculation fields:
| Field | Type | Description |
|---|---|---|
total_zakatable_wealth |
Decimal |
Total wealth subject to Zakat |
nisab_threshold |
Decimal |
Minimum threshold in the given currency |
zakat_due |
Decimal |
Total Zakat amount due |
zakat_rate |
Decimal |
Effective rate applied (e.g. 0.025 for 2.5%) |
is_zakat_obligatory |
bool |
Whether wealth exceeds Nisab |
currency |
str |
Currency code used for the calculation |
breakdown |
dict |
Asset-by-asset Zakat amounts |
calculation_notes |
list[str] |
Notes, warnings, and Nisab details |
calculate_livestock_zakat(camels=0, cattle=0, sheep_goats=0) -> dict
Calculates Zakat on livestock using classical Islamic schedules.
Returned dict keys:
| Key | Description |
|---|---|
camels_zakat |
{"zakat_applicable": bool, "details": str} |
cattle_zakat |
{"zakat_applicable": bool, "details": str} |
sheep_goat_zakat |
{"zakat_applicable": bool, "details": str} |
Minimum thresholds: 5 camels, 30 cattle, 40 sheep/goats.
MarketPrices
MarketPrices(
metal_providers=[GoldPriceOrgProvider(), KitcoProvider()],
bulk_rate_providers=[ExchangeRateApiProvider()],
single_rate_providers=[XeProvider()],
crypto_providers=[CoinGeckoProvider()],
)
| Method | Returns | Description |
|---|---|---|
get_gold_price_per_gram() |
MarketPriceResult |
Live gold price in USD/gram |
get_silver_price_per_gram() |
MarketPriceResult |
Live silver price in USD/gram |
get_exchange_rate(code) |
MarketPriceResult |
USD value of 1 unit of code |
get_crypto_price(symbol) |
MarketPriceResult |
Live crypto price in USD |
refresh() |
None |
Clear cache, force re-fetch |
MarketPriceResult fields: value, source, is_live, timestamp, warning
Custom Market Price Providers
By default, the library fetches live prices from goldprice.org → kitco.com (metals), exchangerate-api.com → xe.com (exchange rates), and coingecko.com (crypto). You can replace or extend any of these by passing your own provider:
from zakat_calculator import MarketPrices, KitcoProvider
class MyGoldProvider:
name = "my-api"
def fetch(self) -> dict:
import requests
data = requests.get("https://my-api.com/metals").json()
return {
"gold_per_gram": data["gold_usd_per_oz"] / 31.1035,
"silver_per_gram": data["silver_usd_per_oz"] / 31.1035,
}
# MyGoldProvider is tried first, KitcoProvider is the fallback
mp = MarketPrices(metal_providers=[MyGoldProvider(), KitcoProvider()])
Built-in providers you can mix and match:
| Provider | Type | Source |
|---|---|---|
GoldPriceOrgProvider |
Metals | goldprice.org |
KitcoProvider |
Metals | kitco.com |
ExchangeRateApiProvider |
Exchange rates (bulk) | exchangerate-api.com |
XeProvider |
Exchange rates (single) | xe.com |
CoinGeckoProvider |
Crypto | coingecko.com |
Testing
python -m unittest discover -s tests
# Run live market price tests (requires network)
RUN_LIVE_TESTS=1 python -m unittest discover -s tests
Contributing
See CONTRIBUTING.md for how to set up your environment, run the pre-commit hooks, and submit a pull request.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file zakat_calculator-0.0.1.tar.gz.
File metadata
- Download URL: zakat_calculator-0.0.1.tar.gz
- Upload date:
- Size: 23.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f02675f7ce6cb3a22942637a15fced850e0c1b12f7f8984b50eccf8af3a93094
|
|
| MD5 |
49ee70ce599a5d986156ecf7a92cf635
|
|
| BLAKE2b-256 |
4cc25851cd1d77bcb20d2295034e903a83c16f08f9e0e1a5f9838e50355b6e2d
|
File details
Details for the file zakat_calculator-0.0.1-py3-none-any.whl.
File metadata
- Download URL: zakat_calculator-0.0.1-py3-none-any.whl
- Upload date:
- Size: 18.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9444acd81b12d3ec194345f4f2071f73c04cff3c8bd2224ec38c7605778259c5
|
|
| MD5 |
6433a89e13add52a5231c5027549f117
|
|
| BLAKE2b-256 |
4af556e4aed952cdec6504e06a5ebbb05cf75bb7aff61399e91cac22e92dbe80
|