您好,登錄后才能下訂單哦!
在使用Django自帶的admin后臺的時候,他提供了一些默認的指令可以對數(shù)據(jù)進行操作, 比如批量刪除,修改等 同樣的我們也可以添加自己的指令。
|- Django版本:1.8
|- Python版本:3.4
models.py
class Story(models.Model): #編輯Story狀態(tài) STATUS_CHOICES = ( (1, '待編輯狀態(tài)'), (2, '待批準狀態(tài)'), (3, '已發(fā)布狀態(tài)'), (4, '已存檔'), ) title = models.CharField(max_length=100, verbose_name=u'文章') slug = models.SlugField(verbose_name=u'簡短標題') category =models.ForeignKey(Category, verbose_name=u'分類') owner = models.ForeignKey(User, verbose_name=u'發(fā)布者') status = models.IntegerField(choices=STATUS_CHOICES, default=1, verbose_name=u'發(fā)布狀態(tài)') class Meta: ordering = ['modified','created'] verbose_name_plural = verbose_name = '文章' def __str__(self): return self.title
admin.py
class StoryAdmin(admin.ModelAdmin): list_display = ('title', 'owner', 'status', 'created', 'modified','read_times','top', 'id') search_fields = ('title', 'markdown_content') # 狀態(tài)選擇器 list_filter = ('status', 'owner', 'created', 'modified',) prepopulated_fields = {'slug': ('title',)} actions = ['make_story_public'] def make_story_public(self, request, queryset): # queryset參數(shù)為選中的Story對象 rows_updated = queryset.update(status=3) message_bit = "%s 篇文章" % rows_updated self.message_user(request, "%s 已成功標記為已發(fā)布狀態(tài)." % message_bit) make_story_public.short_description = u'修改選中文章為已發(fā)布狀態(tài)'
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。