Django之 ArrayAgg與Admin技巧學(xué)習(xí)
Django Admin 技巧
有這樣一個需求, Django 后臺 admin 有一個 select 字段, 其備選項是某個系統(tǒng)路徑下的文件名, 因此下拉列表的備選項是動態(tài)的.
而常規(guī)的 select 聲明方式如下, 其備選項 choices 是靜態(tài)的. 如果目標(biāo)路徑的文件發(fā)生變動, 必須重啟 django 才能獲得更新后的下拉列表.
name = models.CharField(max_length=64, choices = (('0','file1'),('0','file1')))
一個自然思路就是, 重載admin的 formfield_for_choice_field()
, 在函數(shù)內(nèi)部調(diào)用下拉列表獲取方法.
但問題是, 一旦選擇的值不在上面聲明的 choices
中, 表單驗證就會失敗.
正確的做法是取消 choices 約束, 將字段變成純字符串型.
name = models.CharField(max_length=64)
這時候, admin 對name的 widget 會由 select 變?yōu)?input, 這不是我們想要的. 所以需要手動指定:
class RouteForm(forms.ModelForm): class Meta: widgets = { 'name': forms.Select(), } class RouteAdmin(TreeAdmin): form = RouteForm def formfield_for_dbfield(self, db_field, request, **kwargs): if db_field.name == 'name': choices = TextChoices( 'RouteName', get_files() ) kwargs['widget'].choices = choices.choices return super().formfield_for_dbfield(db_field, request, **kwargs)
這時候, 需要重載的函數(shù)就變?yōu)榱?formfield_for_dbfield()
, 按照上述方式構(gòu)造的admin,就能夠?qū)崿F(xiàn)業(yè)務(wù)需求.
Django 技巧之 ArrayAgg
PostgreSQL 提供了聚合類 ArrayAgg, 能夠方便的完成列表的聚合.
Returns a list of values, including nulls, concatenated into an array, or default if there are no values.
例如
class Item(models.Model): name = models.CharField(max_length=20) class A(models.Model): name = models.CharField(max_length=20) items = models.ManyToManyField(to=Item)
打算將A模型序列化成以下形式
[ { "id": 1, "name": "名稱1", "item_list": [ 410,415,416] }, { "id": 2, "name": "名稱2", "item_list": [ 411,415,416] }, ]
也就是說, 將 ManyToManyField 這種外鍵直接序列化成列表形式. 這時候可以采用下述方式
A.objects.annotate( item_list=ArrayAgg('items',distinct=True)).values( 'id', 'name', 'item_list')
非常簡潔優(yōu)雅,且這是數(shù)據(jù)庫底層支持的函數(shù), 所有運行效率也非常高.
可以看出, Django項目采用 PostgreSQL 作為數(shù)據(jù)庫還是非常有價值的.
以上就是Django之 ArrayAgg與Admin技巧學(xué)習(xí)的詳細(xì)內(nèi)容,更多關(guān)于Django技巧ArrayAgg Admin的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python實現(xiàn)的遠(yuǎn)程文件自動打包并下載功能示例
這篇文章主要介紹了Python實現(xiàn)的遠(yuǎn)程文件自動打包并下載功能,結(jié)合實例形式分析了Python使用spawn()方法執(zhí)行ssh、scp 命令實現(xiàn)遠(yuǎn)程文件的相關(guān)操作技巧,需要的朋友可以參考下2019-07-07Django 權(quán)限認(rèn)證(根據(jù)不同的用戶,設(shè)置不同的顯示和訪問權(quán)限)
這篇文章主要介紹了Django 權(quán)限認(rèn)證(根據(jù)不同的用戶,設(shè)置不同的顯示和訪問權(quán)限),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07Python中的response.text與content區(qū)別詳解
這篇文章主要介紹了Python中的response.text與content區(qū)別詳解,?從網(wǎng)絡(luò)請求下來的數(shù)據(jù),他們都是字節(jié)類型的,如果服務(wù)器不指定的話,默認(rèn)編碼是"ISO-8859-1",我們使用text直接拿到的是字符串類型,沒有進行解碼操作,則會出現(xiàn)亂碼問題,需要的朋友可以參考下2023-12-12