Pure Python unit conversion engine for developers. Convert between 200 units across 20 measurement categories with Decimal precision, human-readable formula text, and smart magnitude-aware rounding -- all with zero dependencies.
Convert between 200 units at unitfyi.com -- unit converter, conversion tables, and formula references across length, weight, temperature, volume, and 16 more categories.
- Install
- Quick Start
- Understanding Unit Systems
- Temperature Conversion
- Conversion Tables
- Command-Line Interface
- MCP Server (Claude, Cursor, Windsurf)
- REST API Client
- API Reference
- Categories
- Features
- Learn More About Units
- Utility FYI Family
- License
pip install unitfyi # Core engine (zero deps)
pip install "unitfyi[cli]" # + Command-line interface
pip install "unitfyi[mcp]" # + MCP server for AI assistants
pip install "unitfyi[api]" # + HTTP client for unitfyi.com API
pip install "unitfyi[all]" # Everythingfrom decimal import Decimal
from unitfyi import convert, get_unit, get_category_units, get_ordered_categories
# Convert 100 Celsius to Fahrenheit
result = convert(Decimal("100"), "celsius", "fahrenheit")
result.result # Decimal('212')
result.formula_text # '°F = (°C x 9/5) + 32'
# Convert 5 kilometers to miles
result = convert(Decimal("5"), "kilometer", "mile")
result.result # Decimal('3.1069')
# Look up a unit
unit = get_unit("meter")
unit.name # 'Meter'
unit.symbol # 'm'
unit.category # 'length'
# List all 20 categories
categories = get_ordered_categories()
len(categories) # 20
# List units in a category
units = get_category_units("temperature")
[u.name for u in units] # ['Celsius', 'Fahrenheit', 'Kelvin', 'Rankine']The world's measurement systems evolved from diverse historical origins into three main families:
SI (International System of Units) -- the modern metric system, used by virtually every country for scientific and most commercial purposes. Built on seven base units (meter, kilogram, second, ampere, kelvin, mole, candela) with decimal prefixes from yocto (10^-24) to yotta (10^24).
Imperial / US Customary -- derived from English units. The US and Imperial systems share many unit names (inch, foot, mile, pound) but diverge for volume: a US gallon is 3.785 liters while an Imperial gallon is 4.546 liters. This distinction causes real-world confusion -- always specify which system.
Historical and domain-specific units -- troy ounces for precious metals, nautical miles for maritime navigation, astronomical units for solar system distances, light-years for stellar distances. These persist because they map naturally to the scale of their domain.
| SI Base Unit | Symbol | Measures | Defined By |
|---|---|---|---|
| Meter | m | Length | Speed of light (1/299,792,458 s) |
| Kilogram | kg | Mass | Planck constant (2019 redefinition) |
| Second | s | Time | Caesium-133 hyperfine transition |
| Ampere | A | Electric current | Elementary charge |
| Kelvin | K | Temperature | Boltzmann constant |
| Mole | mol | Amount of substance | Avogadro constant |
| Candela | cd | Luminous intensity | Luminous efficacy of 540 THz radiation |
| SI Prefix | Symbol | Factor | Example |
|---|---|---|---|
| tera | T | 10^12 | 1 TB = 1,000,000,000,000 bytes |
| giga | G | 10^9 | 1 GHz = 1,000,000,000 Hz |
| mega | M | 10^6 | 1 MW = 1,000,000 watts |
| kilo | k | 10^3 | 1 km = 1,000 meters |
| milli | m | 10^-3 | 1 mm = 0.001 meters |
| micro | u | 10^-6 | 1 um = 0.000001 meters |
| nano | n | 10^-9 | 1 nm = 0.000000001 meters |
from decimal import Decimal
from unitfyi import convert
# SI metric prefixes follow powers of 10
convert(Decimal("1"), "kilometer", "meter") # 1000 meters in a kilometer
convert(Decimal("1"), "megabyte", "kilobyte") # 1024 (binary prefix convention)
# Imperial vs US volume -- a common source of confusion
convert(Decimal("1"), "us-gallon", "liter") # 3.7854 liters (US gallon)unitfyi uses Python's Decimal type throughout the conversion pipeline. This eliminates floating-point drift that plagues float-based calculators -- critical for financial calculations (currency amounts), scientific work (precise measurements), and any application where 0.1 + 0.2 != 0.3 would be unacceptable.
Learn more: Browse All Categories · Browse All Units · Glossary
Temperature is the only common measurement category where conversions are non-linear. Length, weight, and volume use simple multiplication by a constant factor (1 km = 1000 m). Temperature requires function-based formulas because the scales have different zero points:
| Scale | Zero Point | Boiling Point of Water | Absolute Zero | Used In |
|---|---|---|---|---|
| Celsius (C) | Water freezes (0) | 100 | -273.15 | Worldwide (science, daily life) |
| Fahrenheit (F) | Brine solution (0) | 212 | -459.67 | US, Belize, Cayman Islands |
| Kelvin (K) | Absolute zero (0) | 373.15 | 0 | Physics, chemistry, astronomy |
| Rankine (R) | Absolute zero (0) | 671.67 | 0 | US engineering (thermodynamics) |
from decimal import Decimal
from unitfyi import convert
# Celsius to Fahrenheit conversion formula: F = (C x 9/5) + 32
result = convert(Decimal("100"), "celsius", "fahrenheit")
result.result # Decimal('212') — water boils at 212 F
result.formula_text # '°F = (°C x 9/5) + 32'
# All temperature conversions route through Kelvin as the base unit
convert(Decimal("0"), "celsius", "kelvin") # Decimal('273.15')
convert(Decimal("-40"), "celsius", "fahrenheit") # Decimal('-40') -- the crossover point
# Rankine -- absolute scale based on Fahrenheit degrees
convert(Decimal("100"), "celsius", "rankine") # Decimal('671.67')Internally, unitfyi routes all temperature conversions through Kelvin as the canonical base unit. For linear categories (length, weight, etc.), each unit stores a single conversion factor relative to the base unit, and conversion is a simple division-then-multiplication. For temperature, each unit provides to_base and from_base functions that encode the non-linear relationship.
Learn more: Temperature Units · Unit Converter · Conversion Tables
Generate reference conversion tables for documentation, educational materials, or quick lookup charts. Tables are computed with full Decimal precision and smart magnitude-aware rounding.
from decimal import Decimal
from unitfyi import conversion_table
# Generate a kilometer-to-mile reference table
table = conversion_table("kilometer", "mile", count=10)
# Returns list of (input_value, output_value) pairs
# Useful for reference charts, documentation, and educational materialsLearn more: Conversion Tables Tool · Browse All Units
pip install "unitfyi[cli]"
unitfyi convert 100 celsius fahrenheit
unitfyi table kilometer mile
unitfyi categories
unitfyi units lengthAdd unit conversion tools to any AI assistant that supports Model Context Protocol.
pip install "unitfyi[mcp]"Add to your claude_desktop_config.json:
{
"mcpServers": {
"unitfyi": {
"command": "python",
"args": ["-m", "unitfyi.mcp_server"]
}
}
}Available tools: convert_unit, conversion_table, list_categories, list_units
pip install "unitfyi[api]"from unitfyi.api import UnitFYI
with UnitFYI() as client:
result = client.convert("100", "celsius", "fahrenheit")
categories = client.categories()
units = client.units("length")Full API documentation at unitfyi.com.
| Function | Description |
|---|---|
convert(value, from_unit, to_unit) -> ConversionResult |
Convert between units with Decimal precision |
conversion_table(from_unit, to_unit, count) -> list |
Generate conversion reference table |
| Function | Description |
|---|---|
get_unit(slug) -> UnitInfo |
Look up unit by slug (name, symbol, category) |
get_category_units(category) -> list[UnitInfo] |
List all units in a category |
get_ordered_categories() -> list[str] |
List all 20 measurement categories |
| Exception | Description |
|---|---|
UnknownUnitError |
Raised when a unit slug is not recognized |
IncompatibleUnitsError |
Raised when converting between different categories |
Length, Weight, Temperature, Volume, Area, Speed, Time, Data Storage, Pressure, Energy, Frequency, Force, Power, Angle, Fuel Economy, Data Transfer Rate, Density, Torque, Cooking, Typography
- 200 units across 20 measurement categories
- Decimal precision -- no floating-point drift
- Linear + non-linear -- temperature uses function-based formulas
- Formula text -- human-readable conversion formulas
- Smart rounding -- magnitude-aware precision
- Conversion tables -- generate reference charts
- CLI -- Rich terminal output with conversion tables
- MCP server -- 4 tools for AI assistants (Claude, Cursor, Windsurf)
- REST API client -- httpx-based client for unitfyi.com API
- Zero dependencies -- pure Python standard library only
- Type-safe -- full type annotations,
py.typedmarker (PEP 561) - Fast -- all conversions under 1ms
- Tools: Unit Converter · Conversion Tables
- Browse: Categories · All Units
- Guides: Glossary · Blog
- API: REST API Docs · OpenAPI Spec
Part of the FYIPedia open-source developer tools ecosystem — everyday developer reference and conversion tools.
| Package | PyPI | npm | Description |
|---|---|---|---|
| unitfyi | PyPI | npm | Unit conversion, 220 units -- unitfyi.com |
| timefyi | PyPI | npm | Timezone ops & business hours -- timefyi.com |
| holidayfyi | PyPI | npm | Holiday dates & Easter calculation -- holidayfyi.com |
| namefyi | PyPI | npm | Korean romanization & Five Elements -- namefyi.com |
| distancefyi | PyPI | npm | Haversine distance & travel times -- distancefyi.com |
MIT
