目录

引入单例----单例补充

admin---url/注册的自定义配置

解析admin源码

django-admin注册账号-----创建超级用户

python manage.py createsuperuser

引入单例----单例补充

类知识补充

from django.test import TestCase

# Create your tests here.

class A(object):
x = 12
def __init__(self):
self.y = 10 class B(A):
x = 20
y = 20 b = B()
print(b.x)
print(b.y) 结果:
20
10

类的取值顺序

  先从对象的空间取----》对象所在的类-----》对象所在的类的父类

几种单例模式

1 基于__new__

class A():
def __new__(cls, *args, **kwargs):
_instance = None
if not _instance:
cls._instance = super().__new__(cls,*args,**kwargs)
return cls._instance a = A()
b = A()
c = A()
print(id(a))
print(id(b))

解析:1 在实例化对象过程中先进行__new__方法,然后把结果返回给__init__

    2 利用第一次,初始化对象继承父类的__new__方法,生成的对象,返回给__init__,然后下次,直接把第一次生成的对象再返回给__init__,保证始终是第一次生成的对象

2 基于模块(python独有的)

# test_modle模块
class A():
def __init__(self):
self.name = 'alex'
def func(self):
print('呵呵') a = A()
print(id(a)) # test_03
import test_modle
def func():
print(id(test_modle.a)) # 执行代码
import test_modle print(id(test_modle.a)) import test_modle print(id(test_modle.a)) from test_03 import func
func() 结果:
3082181927824
3082181927824
3082181927824
3082181927824

解析:

  1 导入模块,会生成一个pyc文件,但只会在第一次生成一个。后面的数据会从pyc文件中获取,与导入多少相同模块无关

  

  2 可以把jiango项目看成一个程序,如果取一个值,如果改值在同一个pyc文件中,无论取值过程中经历多少个模块,都可以看成,直接从相同的pyc文件中取值。

admin---url/注册的自定义配置

url-----对应源码分析url设计

二级路由设置

设计规则:在urls.py文件中的 urlpatterns 中

url(r'路由',[],None,None)

解析:[]中存放下一级路由,即url(r'下一级路由',自定义视图函数名)

     第一个None

     第二个None

多级路由以此类推

参考示例:

urlpatterns = [
url(r'^admin/', admin.site.urls), url(r'index',([
url(r'^$',index),
url(r'test01',test01),
url(r'test02',test02)
],None,None))
# url(r'index/', get_urls())
]

admin中增删改查对应的url

增

http://127.0.0.1:8000/admin/app01/author/add/

删url

http://127.0.0.1:8000/admin/app01/author/1/delete/

改url

http://127.0.0.1:8000/admin/app01/author/1/change/

查url

http://127.0.0.1:8000/admin/app01/author/

模仿admin简单设计(初级版):

设计前知识补充:

model._meta.app_label:获取类对象所在的app名

model._meta.model_name:获取类对象所在的类名

model:类

config_obj:配置类对象对象

from django.conf.urls import url
from django.contrib import admin
from django.shortcuts import HttpResponse
def test01(request):
return HttpResponse('test01')
def test02(request):
return HttpResponse('test02')
def index(request):
return HttpResponse('index')
def show(request):
return HttpResponse('show')
def add(request):
return HttpResponse('add')
def change(request,id):
return HttpResponse('change')
def delete(request,id):
return HttpResponse('delete')
def get_urls2():
item = [
url(r'^$',show),
url(r'add/', add),
url(r'(\d+)/change',change),
url(r'(\d+)/delete', delete)
]
return item, None, None def get_urls():
item=[url(r'^$',index)]
for model,config in admin.site._registry.items():
# print('----->',model,config)
urls = url(r'{}/{}/'.format(model._meta.app_label,model._meta.model_name),get_urls2())
item.append(urls)
return item, None, None urlpatterns = [
# url(r'^admin/', admin.site.urls),
#
# url(r'index',([
# url(r'^$',index),
# url(r'test01',test01),
# url(r'test02',test02)
# ],None,None))
url(r'index/', get_urls())
]

注册的自定义配置

解析:

1  原来,注册时,我们通常默认继承 ModelAdmin类,然后在前端显示

2  我们通过继承ModelAdmin类,覆盖类中的方法,实现自定义效果

使用方法

class BookConfig(admin.ModelAdmin):
list_display = ['title','price','publish','authors']
admin.site.register(Book,BookConfig)

1  list_display = ['title','price','publish','authors']-----将modles.py中的对应表中的字段,展示在admin查的页面中

效果展示

默认

自定义

坑:

  1 list_display 中有多对多/一对多中的多的字段,会报错

ERRORS:
<class 'app01.admin.BookConfig'>: (admin.E109) The value of 'list_display[3]' must not be a ManyToManyField.

  2 ‘hehe’ 等一点都不相干的字段,启动项目就报错

ERRORS:
<class 'app01.admin.BookConfig'>:
(admin.E108) The value of 'list_display[3]' refers to 'hehe',
which is not a callable, an attribute of 'BookConfig', or an attribute or method on 'app01.Book'.
class PublishConfig(admin.ModelAdmin):
list_display = ['name','hehe']
admin.site.register(Publish)
admin.site.register(AuthorDetail,PublishConfig)

  3 即使两张表中是一对多/多对多/一对一 只要该表中没有这个静态书籍,就不能随便添加,否则,可以正常启动,但跳转到相应的web时会报错

页面
AttributeError at /admin/app01/author/
'Author' object has no attribute 'book' 后台
AttributeError: 'Author' object has no attribute 'book'

2 list_display_links = ['price','title']  ----给对应的字段添加a标签,跳转到修改的url

展示

默认 第一个字段

自定义

3  list_filter = ['title','author','publish']------分类

展示

默认

自定义

4 search_fields = ['title','price']-----查询,支持模糊查询

展示

默认

自定义

5 批量操作

   1 def patch_init(self,request,queryset):
queryset.update(price=0)
2 patch_init.short_description = "初始化价格"
3 actions = [patch_init]

1 定义函数(操作数据库)

2 定义选项名称

3 添加函数名

展示

  

解析admin源码

  1 启动

    从settings.py文件中找到 INSTALLED_APPS 配置文件

    又找到admin    from django.contrib import admin

    在admin中找到 from django.contrib.admin.sites import AdminSite, site

    找到setes模块  中的AdminSite, site 初始化对象site

    

    在admin中找到

def autodiscover():
autodiscover_modules('admin', register_to=site)

    从模块中扫描带有admin的文件

    找到app01下的admin

  2 注册  

admin.site.register(Author)
class BookConfig(admin.ModelAdmin):
pass
admin.site.register(Book,BookConfig)

  源码

源码:
admin.py---sites.py---->
class AdminSite(object): def __init__(self):
self._registry = {} def register(self,model,admin_class=None):
if not admin_class:
admin_class = ModelAdmin
self._registry[model] = admin_class(model, self)
site = AdminSite()

  3 urls设计

  

参考文档:Django-admin 管理工具

     自定义配置参考详细

bbs-admin的更多相关文章

  1. 1210 BBS admin后台管理及侧边栏筛选个人站点

    目录 昨日内容 django admin后台管理 使用 建表 用户图片的显示 MEDIA用户配置 查找照片 搭建个人站点 防盗链 新建css文件 侧边栏展示标签 定义分类栏与标签栏 定义时间栏 侧边栏 ...

  2. Thinkphp学习回顾(一)之基本结构目录

    TP框架的学习一般都是从了解框架的基本结构开始的,每个文件都有其专属的作用,我的TP框架的回顾也从基本结构开始讲起. 一.ThinkPHP的获取 http://www.thinkphp.cn   这是 ...

  3. RequestMethod.DELETE相关,如何用jquery实现RequestMethod.DELETE请求

    Spring MVC添加支持Http的delete.put请求!(HiddenHttpMethodFilter) Spring3.0之后->Spring MVC过滤器-HiddenHttpMet ...

  4. linux编译安装LAMP

    Linux安装Apache+MySQL+PHP 安装部分依赖 安装apr(可选) # tar -xf apr-1.5.0.tar.bz2 # cd apr-1.5.0 #./configure --p ...

  5. 重燃你的PHP安全分析之火

    关于脚本安全这个话题好像永远没完没了,如果你经常到国外的各种各样的bugtraq上,你会发现有一半以上都和脚本相关,诸如SQL injection,XSS,Path Disclosure,Remote ...

  6. google 技巧

    inurl: 用于搜索网页上包含的URL. 这个语法对寻找网页上的搜索,帮助之类的很有用. intext: 只搜索网页部分中包含的文字(也就是忽略了标题,URL等的文字). site: 可以限制你搜索 ...

  7. servlet的url-pattern匹配规则

    首先需要明确几容易混淆的规则: servlet容器中的匹配规则既不是简单的通配,也不是正则表达式,而是特定的规则.所以不要用通配符或者正则表达式的匹配规则来看待servlet的url-pattern. ...

  8. web.xml中servlet-mapping的配置

    <servlet-mapping>元素在Servlet和URL样式之间定义一个映射.它包含了两个子元素<servlet- name>和<url-pattern>,& ...

  9. J2ee入门:servlet-mapping的映射配置

    <servlet-mapping>元素在Servlet和URL样式之间定义一个映射.它包含了两个子元素<servlet- name>和<url-pattern> & ...

  10. google 搜索关键字技巧

    google 搜索关键字技巧 来源  https://www.cnblogs.com/qiudabai/articles/9143328.html inurl: 用于搜索网页上包含的URL. 这个语法 ...

随机推荐

  1. Numpy学习之——数组创建

    Numpy学习之--数组创建 过程展示 import numpy as np a = np.array([2,3,9]) a array([2, 3, 9]) a.dtype dtype('int32 ...

  2. PHP接收前端传值各种情况整理

    PHP接收前端传值各种情况整理 服务端代码: header('Access-Control-Allow-Origin:*'); var_dump($_POST); exit; 情况 1) 传null ...

  3. .Net C# 签名字符串排序

    #region Get Sign Content /// <summary> /// Get Sign Content /// </summary> /// <param ...

  4. 关于EF数据迁移的个人总结 简单有效

    有用的拿走,没用的嘴下留情!

  5. 在Pytorch上使用稀疏矩阵

    在Pytorch上使用稀疏矩阵 最近在写一个NLP的小项目,用到了Pytorch做神经网络模型.但是众所周知NLP的一个特点就是特征矩阵是稀疏矩阵,当时处理稀疏矩阵用的是scipy.sparse,现在 ...

  6. react import 配置路径别名'@',简化import Component的方式

    摘要 在react中,大多数业务逻辑都组件化:极大的减轻了代码的冗余度,如果组件的层次比较深的话,组件的import就比较费劲,在import时使用“../../components/test”的方式 ...

  7. 【Distributed】大型网站高并发和高可用

    一.DNS域名解析 二.大型网站系统应有的特点 三.网站架构演变过程 3.1 传统架构 3.2 分布式架构 3.3 SOA架构 3.4 微服务架构 四.高并发设计原则 4.1 拆分系统 4.2 服务化 ...

  8. functools.lru_cache装饰器

    functools.lru_cache装饰器 functools.lru_cache是非常实用的装饰器,他实现了备忘功能它把耗时的函数的结果保存起来,避免传入相同的参数时重复计算.LRU是Least ...

  9. MyBatis 插入失败后爆出 500 ,如何捕获异常?

    我们在使用 Mybatis 的时候,会出现以下场景 数据表里有一些字段被设置为了 不可为 null 但是我们的用户在提交表单的时候没有提交所需的 字段数据 然后 Mybatis 在数据库做操作的时候就 ...

  10. linux基础1_文件类型、拓展名、目录配置

    命令ls -l,显示的第一个属性代表了这个档案的档案类型 [d]:目录 [-]:普通文件 [l]:连接文件 [b]:存储数据以供系统访问的接口设备 [c]:串行接口的端口设备,例如键盘.鼠标 [s]: ...