Django admin
Django admin使用admin appDjango 提供了基于 web 的管理工具。 Django 自动管理工具是 django.contrib 的一部分。你可以在项目的 settings.py 中的 INSTALLED_APPS 看到它: settings.py中 INSTALLED_APPS =
django.contrib是一套庞大的功能集,它是Django基本代码的组成部分。 启用admin管理工具要启动admin管理工具,只需要在 urls.py 中启动admin对应的路由配置项即可。 通常我们正在使用PyCharm生成项目时会在 urls.py 中自动设置好。 django.conf.urls django.contrib urlpatterns =<span style="color: #000000;"> [
url(r<span style="color: #800000;">'<span style="color: #800000;">^admin/<span style="color: #800000;">'<span style="color: #000000;">,admin.site.urls),] 使用admin管理工具首先先启动我们的Django项目,然后在浏览器中访问 http://127.0.0.1:8000/admin/,就能看到登陆界面。(具体网址和端口根据自己环境输入) 使用?python manage.py createsuperuser?来创建管理员账号,来登录admin管理后台。 想要在admin 界面管理某个数据模型(model),我们需要先将该数据模型(model)注册到 admin。 在admin.py中只要按照上面的方式将某个模型类(model class)注册,即可在Admin中实现该model对应的数据表增删改查的功能。 admin的定制这种方式的注册比较简单,如果想要进行更多的定制操作,需要利用ModelAdmin进行操作,如:
= (,admin.site.register(models.Publisher,PublisherAdmin)
<span style="color: #008000;">#<span style="color: #008000;"> 注册方式2
<span style="color: #000000;">@admin.register(models.Book) <span style="color: #0000ff;">class<span style="color: #000000;"> BookAdmin(admin.ModelAdmin): list_display = (<span style="color: #800000;">"<span style="color: #800000;">title<span style="color: #800000;">",<span style="color: #800000;">"<span style="color: #800000;">price<span style="color: #800000;">",<span style="color: #800000;">"<span style="color: #800000;">publish_date<span style="color: #800000;">",<span style="color: #800000;">"<span style="color: #800000;">publisher<span style="color: #800000;">") ModelAdmin中提供了大量的可定制功能,如 ?1.?list_display,列表时,定制显示的列。 = (,,
</span><span style="color: #0000ff;">def</span><span style="color: #000000;"> xxxxx(self,obj):
</span><span style="color: #0000ff;">return</span> <span style="color: #800000;">"</span><span style="color: #800000;">xxxxx</span><span style="color: #800000;">"</span></pre>
2.?list_display_links,列表时,定制列可以点击跳转。 = (,= (,)
3.?list_filter,列表时,定制右侧快速筛选。 4.?list_select_related,列表时,连表查询是否自动select_related 5. list_editable,列表时,可以编辑的列? = (,= (,)
6.?search_fields,列表时,模糊搜索的功能 search_fields </span>= (<span style="color: #800000;">'</span><span style="color: #800000;">user</span><span style="color: #800000;">'</span>,<span style="color: #800000;">'</span><span style="color: #800000;">pwd</span><span style="color: #800000;">'</span>)</pre>
7.?date_hierarchy,列表时,对Date和DateTime类型进行搜索 date_hierarchy </span>= <span style="color: #800000;">'</span><span style="color: #800000;">ctime</span><span style="color: #800000;">'</span></pre>
8 . inlines,详细页面,如果有其他表和当前表做FK,那么详细页面可以进行动态增加和删除 UserInfoInline(admin.StackedInline):
extra ==<span style="color: #0000ff;">class<span style="color: #000000;"> GroupAdminMode(admin.ModelAdmin):
list_display = (<span style="color: #800000;">'<span style="color: #800000;">id<span style="color: #800000;">',<span style="color: #800000;">'<span style="color: #800000;">title<span style="color: #800000;">'<span style="color: #000000;">,) inlines = [UserInfoInline,] 9 action,列表时,定制action中的操作 </span><span style="color: #008000;">#</span><span style="color: #008000;"> 定制Action行为具体方法</span>
<span style="color: #0000ff;">def</span><span style="color: #000000;"> func(self,request,queryset):
</span><span style="color: #0000ff;">print</span><span style="color: #000000;">(self,queryset)
</span><span style="color: #0000ff;">print</span>(request.POST.getlist(<span style="color: #800000;">'</span><span style="color: #800000;">_selected_action</span><span style="color: #800000;">'</span><span style="color: #000000;">))
func.short_description </span>= <span style="color: #800000;">"</span><span style="color: #800000;">中文显示自定义Actions</span><span style="color: #800000;">"</span><span style="color: #000000;">
actions </span>=<span style="color: #000000;"> [func,]
</span><span style="color: #008000;">#</span><span style="color: #008000;"> Action选项都是在页面上方显示</span>
actions_on_top =<span style="color: #000000;"> True
</span><span style="color: #008000;">#</span><span style="color: #008000;"> Action选项都是在页面下方显示</span>
actions_on_bottom =<span style="color: #000000;"> False
</span><span style="color: #008000;">#</span><span style="color: #008000;"> 是否显示选择个数</span>
actions_selection_counter = True</pre>
--------------------------------------------------------------------------------------------------------------------------------- 10. 定制HTML模板 add_form_template ====== None
11. raw_id_fields,详细页面,针对FK和M2M字段变成以Input框形式 raw_id_fields </span>= (<span style="color: #800000;">'</span><span style="color: #800000;">FK字段</span><span style="color: #800000;">'</span>,<span style="color: #800000;">'</span><span style="color: #800000;">M2M字段</span><span style="color: #800000;">'</span>,)</pre>
12. fields,详细页面时,显示字段的字段 = (,)
13. exclude,详细页面时,排除的字段 = (,)
14. readonly_fields,详细页面时,只读字段 = (,)
15. fieldsets,详细页面时,使用fieldsets标签对数据进行分割显示 =: (,: (,,),
: (,
16. 详细页面时,M2M显示时,数据移动选择(方向:上下和左右) = (,)
17. ordering,列表时,数据排序规则 = ( [,]
18.?radio_fields,详细页面时,使用radio显示选项(FK默认使用select) radio_fields = {: admin.VERTICAL}
19. form = ModelForm,用于定制用户请求时候表单验证 app01 django.forms django.forms <span style="color: #0000ff;">class<span style="color: #000000;"> MyForm(ModelForm):
others =<span style="color: #000000;"> fields.CharField()
@admin.register(models.UserInfo)
20. empty_value_display = "列数据为空时,显示默认值" =
list_display </span>= (<span style="color: #800000;">'</span><span style="color: #800000;">user</span><span style="color: #800000;">'</span>,<span style="color: #800000;">'</span><span style="color: #800000;">up</span><span style="color: #800000;">'</span><span style="color: #000000;">)
</span><span style="color: #0000ff;">def</span><span style="color: #000000;"> up(self,obj):
</span><span style="color: #0000ff;">return</span><span style="color: #000000;"> obj.user
up.empty_value_display </span>= <span style="color: #800000;">"</span><span style="color: #800000;">指定列数据为空时,默认显示</span><span style="color: #800000;">"</span></pre>
django.contrib <span style="color: #008000;">#<span style="color: #008000;"> Register your models here.
<span style="color: #0000ff;">from .models <span style="color: #0000ff;">import * <span style="color: #0000ff;">class BookInline(admin.StackedInline): <span style="color: #008000;">#<span style="color: #008000;"> TabularInline <span style="color: #0000ff;">class<span style="color: #000000;"> BookAdmin(admin.ModelAdmin):
<span style="color: #0000ff;">class<span style="color: #000000;"> PublishAdmin(admin.ModelAdmin): admin.site.register(Book,BookAdmin) <span style="color: #008000;">#<span style="color: #008000;"> 第一个参数可以是列表 Django admin源码解析单例模式单例模式(Singleton Pattern)是一种常用的软件设计模式,该模式的主要目的是确保某一个类只有一个实例存在。当你希望在整个系统中,某个类只能出现一个实例时,单例对象就能派上用场。 比如,某个服务器程序的配置信息存放在一个文件中,客户端通过一个 AppConfig 的类来读取配置文件的信息。如果在程序运行期间,有很多地方都需要使用配置文件的内容,也就是说很多地方都需要创建 AppConfig 对象的实例,这就导致系统中存在多个 AppConfig 的实例对象,而这样会严重浪费内存资源,尤其是在配置文件内容很多的情况下。事实上,类似 AppConfig 这样的类,我们希望在程序运行期间只存在一个实例对象。 在 Python 中,我们可以用多种方法来实现单例模式:
为了使类只能出现一个实例,我们可以使用? __new__()方法用来创建实例对象 __init__()方法用来初始化实例对象 ==<span style="color: #0000ff;">class<span style="color: #000000;"> Singleton(object):
_instance =<span style="color: #000000;"> None
<span style="color: #0000ff;">if <span style="color: #800080;">name == <span style="color: #800000;">'<span style="color: #800000;">main<span style="color: #800000;">'<span style="color: #000000;">:p1 = Person(<span style="color: #800000;">"<span style="color: #800000;">deng<span style="color: #800000;">",18<span style="color: #000000;">) p2 = Person(<span style="color: #800000;">"<span style="color: #800000;">deng<span style="color: #800000;">",18<span style="color: #000000;">)
使用模块方式其实,Python 的模块就是天然的单例模式,因为模块在第一次导入时,会生成 .pyc 文件,当第二次导入时,就会直接加载 .pyc 文件,而不会再次执行模块代码。因此,我们只需把相关的函数和数据定义在一个模块中,就可以获得一个单例对象了。 如果我们真的想要一个单例类,可以考虑这样做: ==p1 = Singleton(<span style="color: #800000;">"<span style="color: #800000;">deng<span style="color: #800000;">",18)
使用下面的代码测试一下: singleton <span style="color: #0000ff;">print<span style="color: #000000;">(id(p1))
<span style="color: #0000ff;">print<span style="color: #000000;">(p1.name) p1.name = <span style="color: #800000;">"<span style="color: #800000;">Bob<span style="color: #800000;">" <span style="color: #0000ff;">from singleton <span style="color: #0000ff;">import<span style="color: #000000;"> p1 <span style="color: #0000ff;">print<span style="color: #000000;">(id(p1)) admin执行流程1. 循环加载执行所有已经注册的app中的admin.py文件 ,register_to=site)
2. 执行代码 <span style="color: #0000ff;">class <span style="color: #000000;"> BookAdmin(admin.ModelAdmin):list_display = (<span style="color: #800000;">"<span style="color: #800000;">title<span style="color: #800000;">",<span style="color: #800000;">'<span style="color: #800000;">price<span style="color: #800000;">'<span style="color: #000000;">) admin.site.register(Book,BookAdmin) 3. admin。site 这里应用的是一个单例模式,对于AdminSite类的一个单例模式,执行的每一个app中的每一个admin.site都是一个对象 4. 执行register方法 ModelAdmin(BaseModelAdmin):
<span style="color: #0000ff;">def register(self,model_or_iterable,admin_class=None,**<span style="color: #000000;">options):<span style="color: #0000ff;">if <span style="color: #0000ff;">not<span style="color: #000000;"> admin_class: admin_class =<span style="color: #000000;"> ModelAdmin <span style="color: #008000;">#<span style="color: #008000;"> Instantiate the admin class to save in the registry self._registry[model] = admin_class(model,self) 思考:在每一个app的admin .py中加上 (admin.site._registry)
到这里,注册结束! 5. admin的URL配置 urlpatterns =
</span><span style="color: #0000ff;">def</span><span style="color: #000000;"> get_urls(self):
</span><span style="color: #0000ff;">from</span> django.conf.urls <span style="color: #0000ff;">import</span><span style="color: #000000;"> url,include
urlpatterns </span>=<span style="color: #000000;"> []
</span><span style="color: #008000;">#</span><span style="color: #008000;"> Add in each model's views,and create a list of valid URLS for the</span>
<span style="color: #008000;">#</span><span style="color: #008000;"> app_index</span>
valid_app_labels =<span style="color: #000000;"> []
</span><span style="color: #0000ff;">for</span> model,model_admin <span style="color: #0000ff;">in</span><span style="color: #000000;"> self._registry.items():
urlpatterns </span>+=<span style="color: #000000;"> [
url(r</span><span style="color: #800000;">'</span><span style="color: #800000;">^%s/%s/</span><span style="color: #800000;">'</span> %<span style="color: #000000;"> (model._meta.app_label,model._meta.model_name),include(model_admin.urls)),]
</span><span style="color: #0000ff;">if</span> model._meta.app_label <span style="color: #0000ff;">not</span> <span style="color: #0000ff;">in</span><span style="color: #000000;"> valid_app_labels:
valid_app_labels.append(model._meta.app_label)
</span><span style="color: #0000ff;">return</span><span style="color: #000000;"> urlpatterns
@property
</span><span style="color: #0000ff;">def</span><span style="color: #000000;"> urls(self):
</span><span style="color: #0000ff;">return</span> self.get_urls(),<span style="color: #800000;">'</span><span style="color: #800000;">admin</span><span style="color: #800000;">'</span>,self.name</pre>
6. url()方法的扩展应用 django.shortcuts HttpResponse(<span style="color: #0000ff;">def<span style="color: #000000;"> test02(request):
<span style="color: #0000ff;">return HttpResponse(<span style="color: #800000;">"<span style="color: #800000;">test02<span style="color: #800000;">"<span style="color: #000000;">) urlpatterns =<span style="color: #000000;"> [url(r<span style="color: #800000;">'<span style="color: #800000;">^admin/<span style="color: #800000;">'<span style="color: #000000;">,url(r<span style="color: #800000;">'<span style="color: #800000;">^yuan/<span style="color: #800000;">'<span style="color: #000000;">,([ url(r<span style="color: #800000;">'<span style="color: #800000;">^test01/<span style="color: #800000;">'<span style="color: #000000;">,test01),url(r<span style="color: #800000;">'<span style="color: #800000;">^test02/<span style="color: #800000;">'<span style="color: #000000;">,test02),],None,None)),] <div class="cnblogs_code" onclick="cnblogs_code_show('8ef30d08-7682-472f-80de-71b438b8744e')"> django.conf.urls django.contrib <span style="color: #0000ff;">from django.shortcuts <span style="color: #0000ff;">import<span style="color: #000000;"> HttpResponse
<span style="color: #0000ff;">def<span style="color: #000000;"> change_list_view(request): HttpResponse(<span style="color: #800000;">"<span style="color: #800000;">change_list_view<span style="color: #800000;">"<span style="color: #000000;">)<span style="color: #0000ff;">def<span style="color: #000000;"> add_view(request): <span style="color: #0000ff;">return HttpResponse(<span style="color: #800000;">"<span style="color: #800000;">add_view<span style="color: #800000;">"<span style="color: #000000;">) <span style="color: #0000ff;">def<span style="color: #000000;"> delete_view(request): <span style="color: #0000ff;">return HttpResponse(<span style="color: #800000;">"<span style="color: #800000;">delete_view<span style="color: #800000;">"<span style="color: #000000;">) <span style="color: #0000ff;">def<span style="color: #000000;"> change_view(request): <span style="color: #0000ff;">return HttpResponse(<span style="color: #800000;">"<span style="color: #800000;">change_view<span style="color: #800000;">"<span style="color: #000000;">) <span style="color: #0000ff;">def<span style="color: #000000;"> get_urls():
url_list=<span style="color: #000000;">[] <span style="color: #0000ff;">for model_class,obj <span style="color: #0000ff;">in<span style="color: #000000;"> admin.site._registry.items():
urlpatterns =<span style="color: #000000;"> [ (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |