Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/24.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 有没有办法在模型保存函数中使用Django注册的BaseSetting?_Python_Django_Google Maps_Wagtail - Fatal编程技术网

Python 有没有办法在模型保存函数中使用Django注册的BaseSetting?

Python 有没有办法在模型保存函数中使用Django注册的BaseSetting?,python,django,google-maps,wagtail,Python,Django,Google Maps,Wagtail,我正在重写一个模型的save函数,以查询Google的地理编码API,将相应的纬度/经度坐标保存到一个地址,并将它们保存到模型中 我已使用API密钥在Django admin中注册了一个BaseSetting,并希望在my models.py中访问此注册设置,以避免对API密钥进行硬编码 在视图中处理它不是一个选项,因为我希望尽量减少API调用的数量 下面是一些演示代码: class DropoffLocationPage(models.Model): templates=“locations/

我正在重写一个模型的save函数,以查询Google的地理编码API,将相应的纬度/经度坐标保存到一个地址,并将它们保存到模型中

我已使用API密钥在Django admin中注册了一个BaseSetting,并希望在my models.py中访问此注册设置,以避免对API密钥进行硬编码

在视图中处理它不是一个选项,因为我希望尽量减少API调用的数量

下面是一些演示代码:

class DropoffLocationPage(models.Model):
templates=“locations/dropoff\u location\u page.html”
dropoff_address=models.CharField(最大长度=40,空白=False,空=False)
dropoff_city=models.CharField(最大长度=40,空白=False,空=False)
dropoff_state=models.CharField(最大长度=2,空白=False,空=False)
dropoff_zip=models.CharField(最大长度=5,空白=False,空=False)
衰减单位数量=型号.字符域(最大长度=10,空白=真)
衰减纬度=models.CharField(最大长度=25,空白=True)
衰减经度=models.CharField(最大长度=25,空白=True)
def get_坐标(地址):
....
返回响应['results'][0]['geometry']['location']
def保存(自身、*args、**kwargs):
地址=str(自我)
位置=获取坐标(地址)
self.dropoff_纬度=位置['lat']
self.dropoff_经度=位置['lng']
super(DropoffLocationPage,self).save()
定义(自我):
返回(self.dropoff\u地址+“”+self.dropoff\u城市+“”+self.dropoff\u州+“”+self.dropoff\u邮编+“”+self.dropoff\u单位号)
@寄存器设置
类别设置(基本设置):
maps\u api\u key=models.CharField(
最大长度=255,
help_text=“您的谷歌地图API密钥”
)

您可以使用在save方法中检索
GoogleAppSetting
实例。如果您在一个Wagtail项目中管理多个站点,那么唯一稍微棘手的细节是,在这种情况下,每个站点将有一个设置对象,并且您需要某种方法来决定检索哪个站点。(在view函数中,这不是问题,因为您始终可以使用
GoogleAPISetting.for\u request
获取与当前请求相对应的设置对象)

在这种情况下,这可能无关紧要,因为即使您有多个站点,也没有真正的理由选择一个googleapi键而不是另一个。因此,您可以要求ORM返回它找到的第一个
GoogleApiseting
对象:

def get_coordinates(address):
    setting_obj = GoogleAPISetting.objects.first()
    api_key = setting_obj.maps_api_key
    # ... do something with api_key ...
    return response['results'][0]['geometry']['location']