Measurement Objects¶
The django.contrib.gis.measure
module contains objects that allow
for convenient representation of distance and area units of measure. [1]
Specifically, it implements two objects, Distance
and
Area
– both of which may be accessed via the
D
and A
convenience aliases, respectively.
Example¶
Distance
objects may be instantiated using a keyword argument indicating the
context of the units. In the example below, two different distance objects are
instantiated in units of kilometers (km
) and miles (mi
):
>>> from django.contrib.gis.measure import D, Distance
>>> d1 = Distance(km=5)
>>> print(d1)
5.0 km
>>> d2 = D(mi=5) # `D` is an alias for `Distance`
>>> print(d2)
5.0 mi
For conversions, access the preferred unit attribute to get a converted distance quantity:
>>> print(d1.mi) # Converting 5 kilometers to miles
3.10685596119
>>> print(d2.km) # Converting 5 miles to kilometers
8.04672
Moreover, arithmetic operations may be performed between the distance objects:
>>> print(d1 + d2) # Adding 5 miles to 5 kilometers
13.04672 km
>>> print(d2 - d1) # Subtracting 5 kilometers from 5 miles
1.89314403881 mi
Two Distance
objects multiplied together will yield an Area
object, which uses squared units of measure:
>>> a = d1 * d2 # Returns an Area object.
>>> print(a)
40.2336 sq_km
To determine what the attribute abbreviation of a unit is, the unit_attname
class method may be used:
>>> print(Distance.unit_attname("US Survey Foot"))
survey_ft
>>> print(Distance.unit_attname("centimeter"))
cm
Supported units¶
Unit Attribute |
Full name or alias(es) |
---|---|
|
Kilometre, Kilometer |
|
Mile |
|
Meter, Metre |
|
Yard |
|
Foot, Foot (International) |
|
U.S. Foot, US survey foot |
|
Inches |
|
Centimeter |
|
Millimetre, Millimeter |
|
Micrometer, Micrometre |
|
British foot (Sears 1922) |
|
British yard (Sears 1922) |
|
British chain (Sears 1922) |
|
Indian yard, Yard (Indian) |
|
Yard (Sears) |
|
Clarke’s Foot |
|
Chain |
|
Chain (Benoit) |
|
Chain (Sears) |
|
British chain (Benoit 1895 B) |
|
British chain (Sears 1922 truncated) |
|
Gold Coast foot |
|
Link |
|
Link (Benoit) |
|
Link (Sears) |
|
Clarke’s link |
|
Fathom |
|
Rod |
|
Furlong, Furrow Long |
|
Nautical Mile |
|
Nautical Mile (UK) |
|
German legal metre |
Note
Area
attributes are the same as Distance
attributes,
except they are prefixed with sq_
(area units are square in nature).
For example, Area(sq_m=2)
creates an Area
object
representing two square meters.
In addition to unit with the sq_
prefix, the following units are also
supported on Area
:
Unit Attribute |
Full name or alias(es) |
---|---|
|
Hectare |
Support for the ha
unit was added.
Measurement API¶
Distance
¶
- class Distance(**kwargs)[source]¶
To initialize a distance object, pass in a keyword corresponding to the desired unit attribute name set with desired value. For example, the following creates a distance object representing 5 miles:
>>> dist = Distance(mi=5)
- __getattr__(unit_att)¶
Returns the distance value in units corresponding to the given unit attribute. For example:
>>> print(dist.km) 8.04672
- classmethod unit_attname(unit_name)¶
Returns the distance unit attribute name for the given full unit name. For example:
>>> Distance.unit_attname("Mile") 'mi'
Area
¶
- class Area(**kwargs)[source]¶
To initialize an area object, pass in a keyword corresponding to the desired unit attribute name set with desired value. For example, the following creates an area object representing 5 square miles:
>>> a = Area(sq_mi=5)
- __getattr__(unit_att)¶
Returns the area value in units corresponding to the given unit attribute. For example:
>>> print(a.sq_km) 12.949940551680001
- classmethod unit_attname(unit_name)¶
Returns the area unit attribute name for the given full unit name. For example:
>>> Area.unit_attname("Kilometer") 'sq_km'
Footnotes