• 3.1
  • 3.2
  • 6.1
  • Версия документации: 5.0

Объекты измерения

Модуль 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

Поддерживаемые единицы

Атрибут единицы

Полное имя или псевдоним(а)

км

Километр, Километр

ми

Миля

м

Метр, Метр

яд

Площадка

футы

Фут, Фут (международный)

survey_ft

Фут США, геодезический фут США

дюйм

Дюймы

см

Сантиметр

мм

Миллиметр, Миллиметр

`` хм``

Микрометр, Микрометр

british_ft

Британская нога (Сирс, 1922)

британский_yd

Британский двор (Сирс, 1922)

british_chain_sears

Британская сеть магазинов (Sears, 1922 г.)

indian_yd

Индийский двор, Двор (Индийский)

sears_yd

Ярд (Сирс)

clarke_ft

Нога Кларка

цепочка

Цепь

chain_benoit

Цепочка (Бенуа)

chain_sears

Цепочка (Сирс)

british_chain_benoit

Британская цепь (Бенуа 1895 Б)

british_chain_sears_truncated

Британская сеть (Sears, 1922 г., усеченная)

gold_coast_ft

Нога Золотого Берега

ссылка

Связь

link_benoit

Линк (Бенуа)

link_sears

Линк (Сирс)

clarke_link

ссылка Кларка

глубина

глубина

стержень

Стержень

фарлонг

Фарлонг, Борозда длинная

нм

Морская миля

nm_uk

Морская миля (Великобритания)

german_m

Немецкий юридический счетчик

Примечание

Атрибуты Area такие же, как атрибуты Distance, за исключением того, что они имеют префикс sq_ (единицы площади по своей природе имеют квадратную форму). Например, Area(sq_m=2) создает объект Area, представляющий два квадратных метра.

Помимо единиц измерения с префиксом sq_, в Area также поддерживаются следующие единицы измерения:

Атрибут единицы

Полное имя или псевдоним(а)

ха

Га

Changed in Django 5.1:

Добавлена ​​поддержка единицы «ха».

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 D

Псевдоним класса Distance.

Площадь

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'
class A

Псевдоним класса Area.

Сноски

Back to Top