當前位置: 首頁>>代碼示例>>Python>>正文


Python sql.AreaField方法代碼示例

本文整理匯總了Python中django.contrib.gis.db.models.sql.AreaField方法的典型用法代碼示例。如果您正苦於以下問題:Python sql.AreaField方法的具體用法?Python sql.AreaField怎麽用?Python sql.AreaField使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在django.contrib.gis.db.models.sql的用法示例。


在下文中一共展示了sql.AreaField方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: as_sql

# 需要導入模塊: from django.contrib.gis.db.models import sql [as 別名]
# 或者: from django.contrib.gis.db.models.sql import AreaField [as 別名]
def as_sql(self, compiler, connection):
        if connection.ops.geography:
            # Geography fields support area calculation, returns square meters.
            self.output_field = AreaField('sq_m')
        elif not self.output_field.geodetic(connection):
            # Getting the area units of the geographic field.
            units = self.output_field.units_name(connection)
            if units:
                self.output_field = AreaField(
                    AreaMeasure.unit_attname(self.output_field.units_name(connection))
                )
            else:
                self.output_field = FloatField()
        else:
            # TODO: Do we want to support raw number areas for geodetic fields?
            raise NotImplementedError('Area on geodetic coordinate systems not supported.')
        return super(Area, self).as_sql(compiler, connection) 
開發者ID:ComputerSocietyUNB,項目名稱:CodingDojo,代碼行數:19,代碼來源:functions.py

示例2: as_oracle

# 需要導入模塊: from django.contrib.gis.db.models import sql [as 別名]
# 或者: from django.contrib.gis.db.models.sql import AreaField [as 別名]
def as_oracle(self, compiler, connection):
        self.output_field = AreaField('sq_m')  # Oracle returns area in units of meters.
        return super(Area, self).as_oracle(compiler, connection) 
開發者ID:ComputerSocietyUNB,項目名稱:CodingDojo,代碼行數:5,代碼來源:functions.py

示例3: area

# 需要導入模塊: from django.contrib.gis.db.models import sql [as 別名]
# 或者: from django.contrib.gis.db.models.sql import AreaField [as 別名]
def area(self, tolerance=0.05, **kwargs):
        """
        Returns the area of the geographic field in an `area` attribute on
        each element of this GeoQuerySet.
        """
        # Peforming setup here rather than in `_spatial_attribute` so that
        # we can get the units for `AreaField`.
        procedure_args, geo_field = self._spatial_setup('area', field_name=kwargs.get('field_name', None))
        s = {'procedure_args' : procedure_args,
             'geo_field' : geo_field,
             'setup' : False,
             }
        connection = connections[self.db]
        backend = connection.ops
        if backend.oracle:
            s['procedure_fmt'] = '%(geo_col)s,%(tolerance)s'
            s['procedure_args']['tolerance'] = tolerance
            s['select_field'] = AreaField('sq_m') # Oracle returns area in units of meters.
        elif backend.postgis or backend.spatialite:
            if backend.geography:
                # Geography fields support area calculation, returns square meters.
                s['select_field'] = AreaField('sq_m')
            elif not geo_field.geodetic(connection):
                # Getting the area units of the geographic field.
                s['select_field'] = AreaField(Area.unit_attname(geo_field.units_name(connection)))
            else:
                # TODO: Do we want to support raw number areas for geodetic fields?
                raise Exception('Area on geodetic coordinate systems not supported.')
        return self._spatial_attribute('area', s, **kwargs) 
開發者ID:VirtualPlants,項目名稱:tissuelab,代碼行數:31,代碼來源:query.py


注:本文中的django.contrib.gis.db.models.sql.AreaField方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。