# 优化经纬度获取方式

This commit is contained in:
xianfuxing 2020-06-08 17:45:24 +08:00
parent d885608444
commit d98445657f
3 changed files with 59 additions and 6 deletions

View File

@ -28,6 +28,8 @@ class DeviceCountSerializer(serializers.ModelSerializer):
signal = serializers.SerializerMethodField() signal = serializers.SerializerMethodField()
energy = serializers.SerializerMethodField() energy = serializers.SerializerMethodField()
calc_time = serializers.SerializerMethodField() calc_time = serializers.SerializerMethodField()
longitude = serializers.SerializerMethodField()
latitude = serializers.SerializerMethodField()
class Meta: class Meta:
model = DeviceCount model = DeviceCount
@ -43,6 +45,10 @@ class DeviceCountSerializer(serializers.ModelSerializer):
'latitude' 'latitude'
] ]
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.device = None
def get_mosq_count(self, obj): def get_mosq_count(self, obj):
return obj.count return obj.count
@ -57,17 +63,32 @@ class DeviceCountSerializer(serializers.ModelSerializer):
def get_device_name(self, obj): def get_device_name(self, obj):
device_id = obj.device_id device_id = obj.device_id
device_name = cache.get(device_id) device = cache.get(device_id)
if device_name: if device:
return device_name self.device = device
return device.device_name
qs = CelexDeviceInfo.objects.filter(device_id=device_id) qs = CelexDeviceInfo.objects.filter(device_id=device_id)
if qs.count() > 0: if qs.count() > 0:
device = qs[0] device = qs[0]
device_name = device.device_name self.device = device
cache.set(device_id, device_name, 60 * 60 * 24) cache.set(device_id, device, 60 * 60 * 24)
return device_name return device.device_name
return None return None
def get_longitude(self, obj):
device = self.device
if device:
if device.longitude:
return device.longitude
return obj.longitude
def get_latitude(self, obj):
device = self.device
if device:
if device.latitude:
return device.latitude
return obj.latitude
class DeviceInfoSerializer(serializers.ModelSerializer): class DeviceInfoSerializer(serializers.ModelSerializer):
device_name = serializers.SerializerMethodField() device_name = serializers.SerializerMethodField()
@ -94,11 +115,13 @@ class DeviceInfoSerializer(serializers.ModelSerializer):
def __init__(self, *args, **kwargs): def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs) super().__init__(*args, **kwargs)
self.latest = None self.latest = None
self.cur_device = None
def get_device_name(self, obj): def get_device_name(self, obj):
qs = CelexDeviceInfo.objects.filter(device_id=obj.device_id) qs = CelexDeviceInfo.objects.filter(device_id=obj.device_id)
if qs.count() > 0: if qs.count() > 0:
device = qs[0] device = qs[0]
self.cur_device = device
return device.device_name return device.device_name
return None return None
@ -125,6 +148,11 @@ class DeviceInfoSerializer(serializers.ModelSerializer):
return 0 return 0
def get_coordinate(self, obj): def get_coordinate(self, obj):
if self.cur_device:
lon, lat = [self.cur_device.longitude, self.cur_device.latitude]
if lon and lat:
return [lon, lat]
query = DeviceCount.objects.filter(~Q(longitude=0), device_id=obj.device_id).order_by('-data_time') query = DeviceCount.objects.filter(~Q(longitude=0), device_id=obj.device_id).order_by('-data_time')
if query: if query:
q = query[0] q = query[0]

View File

@ -0,0 +1,23 @@
# Generated by Django 2.2.4 on 2020-06-08 09:09
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('mosquito', '0016_auto_20200603_1741'),
]
operations = [
migrations.AddField(
model_name='deviceinfo',
name='latitude',
field=models.FloatField(blank=True, null=True, verbose_name='维度'),
),
migrations.AddField(
model_name='deviceinfo',
name='longitude',
field=models.FloatField(blank=True, null=True, verbose_name='经度'),
),
]

View File

@ -91,6 +91,8 @@ class Org(models.Model):
class DeviceInfo(models.Model): class DeviceInfo(models.Model):
device_id = models.CharField(max_length=100, unique=True, verbose_name='设备ID') device_id = models.CharField(max_length=100, unique=True, verbose_name='设备ID')
device_name = models.CharField(max_length=100, blank=True, null=True, verbose_name='设备名称') device_name = models.CharField(max_length=100, blank=True, null=True, verbose_name='设备名称')
longitude = models.FloatField(blank=True, null=True, verbose_name='经度')
latitude = models.FloatField(blank=True, null=True, verbose_name='维度')
org = models.ForeignKey(Org, verbose_name='所在组织', on_delete='PROTECT') org = models.ForeignKey(Org, verbose_name='所在组织', on_delete='PROTECT')
class Meta: class Meta: