测量对象

django.contrib.gis.measure 模块包含了方便表示距离和面积单位的对象。具体来说,它实现了两个对象,DistanceArea —— 这两个对象都可以通过分别使用 DA 的便捷别名来访问。

例如

可以使用指示单位上下文的关键字参数来实例化 Distance 对象。在下面的示例中,使用单位为千米(km)和英里(mi)来实例化两个不同的距离对象:

  1. >>> from django.contrib.gis.measure import D, Distance
  2. >>> d1 = Distance(km=5)
  3. >>> print(d1)
  4. 5.0 km
  5. >>> d2 = D(mi=5) # `D` is an alias for `Distance`
  6. >>> print(d2)
  7. 5.0 mi

要进行转换,访问首选单位属性以获取转换后的距离数量:

  1. >>> print(d1.mi) # Converting 5 kilometers to miles
  2. 3.10685596119
  3. >>> print(d2.km) # Converting 5 miles to kilometers
  4. 8.04672

此外,可以在距离对象之间执行算术操作:

  1. >>> print(d1 + d2) # Adding 5 miles to 5 kilometers
  2. 13.04672 km
  3. >>> print(d2 - d1) # Subtracting 5 kilometers from 5 miles
  4. 1.89314403881 mi

两个 Distance 对象相乘将产生一个 Area 对象,它使用单位的平方:

  1. >>> a = d1 * d2 # Returns an Area object.
  2. >>> print(a)
  3. 40.2336 sq_km

要确定单位的属性缩写是什么,可以使用 unit_attname 类方法:

  1. >>> print(Distance.unit_attname("US Survey Foot"))
  2. survey_ft
  3. >>> print(Distance.unit_attname("centimeter"))
  4. cm

支持的单位

单位属性全名或别名
kmKilometre, Kilometer
miMile
mMeter, Metre
ydYard
ftFoot, Foot (International)
survey_ftU.S. Foot, US survey foot
inchInches
cmCentimeter
mmMillimetre, Millimeter
umMicrometer, Micrometre
british_ftBritish foot (Sears 1922)
british_ydBritish yard (Sears 1922)
british_chain_searsBritish chain (Sears 1922)
indian_ydIndian yard, Yard (Indian)
sears_ydYard (Sears)
clarke_ftClarke’s Foot
chainChain
chain_benoitChain (Benoit)
chain_searsChain (Sears)
british_chain_benoitBritish chain (Benoit 1895 B)
british_chain_sears_truncatedBritish chain (Sears 1922 truncated)
gold_coast_ftGold Coast foot
link链接
link_benoitLink (Benoit)
link_searsLink (Sears)
clarke_linkClarke’s link
fathomFathom
rodRod
furlongFurlong, Furrow Long
nmNautical Mile
nm_ukNautical Mile (UK)
german_mGerman legal metre

备注

Area 的属性与 Distance 的属性相同,只是它们以 sq_ 为前缀(面积单位是平方单位)。例如,Area(sq_m=2) 创建一个表示两平方米的 Area 对象。

测量 API

Distance

class Distance(**kwargs)[源代码]

要初始化一个距离对象,请传递一个关键字,该关键字对应于所需的 单位属性名称 并设置所需的值。例如,以下代码创建一个表示 5 英里的距离对象:

  1. >>> dist = Distance(mi=5)
  • __getattr__(unit_att)

返回与给定单位属性对应的距离值。例如:

  1. >>> print(dist.km)
  2. 8.04672
  • classmethod unit_attname(unit_name)

返回给定完整单位名称的距离单位属性名称。例如:

  1. >>> Distance.unit_attname("Mile")
  2. 'mi'

class D

Distance 类的别名。

Area

class Area(**kwargs)[源代码]

要初始化一个面积对象,请传入一个与所需的 单位属性名称 对应的关键字,并设置所需的值。例如,以下代码创建了一个表示 5 平方英里的面积对象:

  1. >>> a = Area(sq_mi=5)
  • __getattr__(unit_att)

返回与给定单位属性对应的面积值。例如:

  1. >>> print(a.sq_km)
  2. 12.949940551680001
  • classmethod unit_attname(unit_name)

返回给定完整单位名称的面积单位属性名称。例如:

  1. >>> Area.unit_attname("Kilometer")
  2. 'sq_km'

class A

Area 类的别名。

脚注

[1]Robert Coup 是度量对象的初始作者,受到了 geopy 中 Brian Beck 的工作以及 Geoff Biggs 在机器人领域的维度单位方面的博士研究的启发。