Объекты измерения¶
Модуль django.contrib.gis.measure содержит объекты, которые позволяют удобно представлять единицы измерения расстояния и площади. [1] В частности, он реализует два объекта: Distance и Area — к обоим из которых можно получить доступ через удобные псевдонимы D и A соответственно.
Пример¶
Объекты Distance могут быть созданы с использованием аргумента ключевого слова, указывающего контекст единиц измерения. В приведенном ниже примере два разных объекта расстояния создаются в километрах («км») и милях («ми»):
>>> 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
Для преобразований обратитесь к атрибуту предпочтительной единицы измерения, чтобы получить преобразованную величину расстояния:
>>> print(d1.mi) # Converting 5 kilometers to miles
3.10685596119
>>> print(d2.km) # Converting 5 miles to kilometers
8.04672
Кроме того, между объектами расстояния могут выполняться арифметические операции:
>>> print(d1 + d2) # Adding 5 miles to 5 kilometers
13.04672 km
>>> print(d2 - d1) # Subtracting 5 kilometers from 5 miles
1.89314403881 mi
Два объекта Distance, перемноженные вместе, дадут объект Area, который использует квадратичные единицы измерения:
>>> a = d1 * d2 # Returns an Area object.
>>> print(a)
40.2336 sq_km
Чтобы определить аббревиатуру атрибута единицы, можно использовать метод класса unit_attname:
>>> print(Distance.unit_attname("US Survey Foot"))
survey_ft
>>> print(Distance.unit_attname("centimeter"))
cm
Поддерживаемые единицы¶
Атрибут единицы |
Полное имя или псевдоним(а) |
|---|---|
|
Километр, Километр |
|
Миля |
|
Метр, Метр |
|
Площадка |
|
Фут, Фут (международный) |
|
Фут США, геодезический фут США |
|
Дюймы |
|
Сантиметр |
|
Миллиметр, Миллиметр |
`` хм`` |
Микрометр, Микрометр |
|
Британская нога (Сирс, 1922) |
|
Британский двор (Сирс, 1922) |
|
Британская сеть магазинов (Sears, 1922 г.) |
|
Индийский двор, Двор (Индийский) |
|
Ярд (Сирс) |
|
Нога Кларка |
|
Цепь |
|
Цепочка (Бенуа) |
|
Цепочка (Сирс) |
|
Британская цепь (Бенуа 1895 Б) |
|
Британская сеть (Sears, 1922 г., усеченная) |
|
Нога Золотого Берега |
|
Связь |
|
Линк (Бенуа) |
|
Линк (Сирс) |
|
ссылка Кларка |
|
глубина |
|
Стержень |
|
Фарлонг, Борозда длинная |
|
Морская миля |
|
Морская миля (Великобритания) |
|
Немецкий юридический счетчик |
Примечание
Атрибуты Area такие же, как атрибуты Distance, за исключением того, что они имеют префикс sq_ (единицы площади по своей природе имеют квадратную форму). Например, Area(sq_m=2) создает объект Area, представляющий два квадратных метра.
Помимо единиц измерения с префиксом sq_, в Area также поддерживаются следующие единицы измерения:
Атрибут единицы |
Полное имя или псевдоним(а) |
|---|---|
|
Га |
Добавлена поддержка единицы «ха».
API измерений¶
Расстояние¶
- class Distance(**kwargs)¶
Чтобы инициализировать объект расстояния, передайте ключевое слово, соответствующее желаемому имени атрибута unit name, установленному с желаемым значением. Например, следующий пример создает объект расстояния, представляющий 5 миль:
>>> dist = Distance(mi=5)
- __getattr__(unit_att)¶
Возвращает значение расстояния в единицах, соответствующее данному атрибуту единицы. Например:
>>> print(dist.km) 8.04672
- classmethod unit_attname(unit_name)¶
Возвращает имя атрибута единицы расстояния для данного полного имени единицы. Например:
>>> Distance.unit_attname("Mile") 'mi'
Площадь¶
- class Area(**kwargs)¶
Чтобы инициализировать объект области, передайте ключевое слово, соответствующее желаемому имени атрибута unit, установленному с желаемым значением. Например, следующая команда создает объект площади площадью 5 квадратных миль:
>>> a = Area(sq_mi=5)
- __getattr__(unit_att)¶
Возвращает значение площади в единицах, соответствующее данному атрибуту единицы. Например:
>>> print(a.sq_km) 12.949940551680001
- classmethod unit_attname(unit_name)¶
Возвращает имя атрибута единицы площади для данного полного имени единицы. Например:
>>> Area.unit_attname("Kilometer") 'sq_km'
Сноски