路径xadmin-master\demo_app\app\models.py

 class c(models.Model):
ip_address = models.CharField(max_length=16) #host = models.ForeignKey(Host) 注意此行,添加的是外键查询 name = models.CharField(max_length=16)
testlist = models.CharField(max_length=16) def __unicode__(self):
return '%s c [%s] %s %s' % (self.ip_address.name, self.id,
self.testlist, self.name)
class Meta:
#app_label = u'waf日志' #更改数据表表名
db_table = 'testc' #更改django默认前缀数据库命名规则,详情代码外
verbose_name = u"Awaf Log" #app菜单名字,如果没有则为 name+s,加u是中文
verbose_name_plural = verbose_name

关于models.py的相关

'''

db_table

django默认的数据库命名是加上创建appname_xxx

此功能可以突破,

比如说我的app名字是xadmin,数据库名字c,则默认的就是xadmin_c,数据库名字为xadmin.c,

使用     db_table = 'testc'   则xadmin.c数据库变为testc

操作完后创建在models中新建的规则的表(如果你是自己在mysql新建或者从其他地方导入mysql里的表,非app前缀的表,想使用这些表,继续往下看我的low思路,大牛留情)

python manage.py makemigrations

python manage.py migrate

会在字符命令行中发现 以创建 c 表,注意不是testc

之后在xadmin-master\demo_app\app\adminx.py

from models import IDC, Host, MaintainLog, HostGroup, AccessRecord, c #注意是c

 class MaintainLogAdmin1(object):
list_display = (
'ip_address', 'name', 'testlist')
list_display_links = ('ip_address',) list_filter = ['ip_address', 'name', 'testlist']
search_fields = ['ip_address'] form_layout = (
Col("col2",
Fieldset('ip_address',
'name', 'testlist',
css_class='unsort short_label no_title'
),
span=9, horizontal=True
),
Col("col1",
Fieldset('ip_address',
'name', 'testlist'
),
span=3
)
)
reversion_enable = True
xadmin.sites.site.register(c,MaintainLogAdmin1) #看这里,注意导入的是c,也就是上文提到的,在命令行看见创建成功记录的表名

adminx.py 关于应用模板

不出意外,刷新页面成功了,有问题,咱讨论讨论,我是菜鸟,这里主要就是关于models.py里的模板类里的 class Meta:中db_table的使用,感兴趣的去千百度这个类

如果你的数据库表是从外部导入的非app前缀的,有几种思路,最low的就是替换法,return到最上面,创建一个和你从外部导入的表一样名字的表,然后在mysql图形界面客户端更改替换,注意在models里的规则要一直,复制粘贴的时候要注意是否有外键,罗嗦完毕

还有比较高级的思路,就是用数据库的触发器更新,当一个表更新的时候,自动同步到另一个表,知乎上有,么么哒

'''

关于修改xadmin 首页 标题 和 首页 页脚 标题 网上也有,还有修改xadmin菜单图标

在xadmin-master\demo_app\app\adminx.py

class GlobalSetting(object):
site_title = 'Awaf L0g System' #修改首页标题
site_footer = 'Awaf_Team'#修改首页页脚标题
#global_search_models = [Host, IDC]
global_models_icon = {
Host: 'fa fa-laptop', c: 'fa fa-cloud', #修改菜单图标 大概格式就是fa fa-xxx,这里我把idc的图标改成了c的图标
}
menu_style = 'default'#'accordion'
xadmin.sites.site.register(views.CommAdminView, GlobalSetting)

 ----------更新

在用

python manage.py makemigrations

python manage.py migrate

更改数据库表名的时候,如果出现太乱的话,由于之前创建删除多个模块,导致太乱,

到xadmin-master\demo_app\app\migrations 删除多余再更新创建

  

关于django xadmin的学习改造(菜单名称,更改默认前缀数据库)的更多相关文章

  1. 第三百七十六节,Django+Xadmin打造上线标准的在线教育平台—创建用户操作app,在models.py文件生成5张表,用户咨询表、课程评论表、用户收藏表、用户消息表、用户学习表

    第三百七十六节,Django+Xadmin打造上线标准的在线教育平台—创建用户操作app,在models.py文件生成5张表,用户咨询表.课程评论表.用户收藏表.用户消息表.用户学习表 创建名称为ap ...

  2. Django+xadmin打造在线教育平台(二)

    三.xadmin后台管理 3.1.xadmin的安装 django2.0的安装(源码安装方式): https://github.com/sshwsfc/xadmin/tree/django2 把zip ...

  3. django+xadmin在线教育平台(十)

    剩余app model注册 courses注册 新建courses/adminx.py: # encoding: utf-8 __author__ = 'mtianyan' __date__ = '2 ...

  4. Django+xadmin打造在线教育平台(一)

    目录 在线教育平台(一)      在线教育平台(二) 在线教育平台(三)      在线教育平台(四) 在线教育平台(五)      在线教育平台(六) 在线教育平台(七)      在线教育平台( ...

  5. 第三百九十五节,Django+Xadmin打造上线标准的在线教育平台—Xadmin集成富文本框

    第三百九十五节,Django+Xadmin打造上线标准的在线教育平台—Xadmin集成富文本框 首先安装DjangoUeditor3模块 Ueditor HTML编辑器是百度开源的HTML编辑器 下载 ...

  6. 第三百九十四节,Django+Xadmin打造上线标准的在线教育平台—Xadmin后台进阶开发配置2,以及目录结构说明

    第三百九十四节,Django+Xadmin打造上线标准的在线教育平台—Xadmin后台进阶开发配置2,以及目录结构说明 设置后台列表页面可以直接修改字段内容 在当前APP里的adminx.py文件里的 ...

  7. 第三百八十节,Django+Xadmin打造上线标准的在线教育平台—将所有app下的models数据库表注册到xadmin后台管理

    第三百八十节,Django+Xadmin打造上线标准的在线教育平台—将所有app下的models数据库表注册到xadmin后台管理 将一个app下的models数据库表注册到xadmin后台管理 重点 ...

  8. 第三百七十四节,Django+Xadmin打造上线标准的在线教育平台—创建课程app,在models.py文件生成4张表,课程表、课程章节表、课程视频表、课程资源表

    第三百七十四节,Django+Xadmin打造上线标准的在线教育平台—创建课程app,在models.py文件生成4张表,课程表.课程章节表.课程视频表.课程资源表 创建名称为app_courses的 ...

  9. Python升级3.6 强力Django+Xadmin打造在线教育平台

    第 1 章 课程介绍 1-1 项目演示和课程介绍: 第 2 章 Windows下搭建开发环境 2-1 Pycharm.Navicat和Python解释器的安装: Pycharmhttp://www.j ...

随机推荐

  1. 测试数学公式latex

    \( J_\alpha(x) = \sum\limits_{m=0}^\infty \frac{(-1)^m}{m! + 1)}{\left({\frac{x}{2}}\right)}^{2 m + ...

  2. sqlserver 2008 孤立用户解决方法

    从别一台服务器上得到一个数据库备份.还原到本地,数据库中的用户无法登录,也就是联机帮助中说的还原备份可能产生的孤立用户问题. 一.新建一个 MyDataBase 数据库 二.把备份文件放到 C 盘根目 ...

  3. 野心勃勃的React组件生命周期

    当你还在写着Angular指令,过滤器,注入,服务,提供者,视图模版的时候,是不是觉得很烦,好在这个时候,React已经神一样的出现在历史舞台. React组件    React实现了UI=Fn(St ...

  4. C++中的文件读取结束

    while(cin>>N>>M) { } ok???

  5. javascript中的克隆

    一:节点克隆 var p = document.getElementsByTagName("p")[0]; var cP = p.cloneNode();//克隆p节点 var c ...

  6. Spark的Straggler深入学习(2):思考Block和Partition的划分问题——以论文为参考

    一.partition的划分问题 如何划分partition对block数据的收集有很大影响.如果需要根据block来加速task的执行,partition应该满足什么条件? 参考思路1:range ...

  7. 用户、角色、权限三者多对多用hibernate的一对多注解配置

    用户.角色.权限三者多对多用hibernate的一对多注解配置 //权限表@Table(name = "p")public class P { @Id @GeneratedValu ...

  8. 【three.js详解之一】入门篇

    [three.js详解之一]入门篇   开场白 webGL可以让我们在canvas上实现3D效果.而three.js是一款webGL框架,由于其易用性被广泛应用.如果你要学习webGL,抛弃那些复杂的 ...

  9. 转载——C++控制台贪吃蛇代码

    游戏截图: 以下是3个代码文件: Snake_Class.h文件: 1 #ifndef SNAKE 2 #define SNAKE 3 4 #include<windows.h> 5 #i ...

  10. 开始学习Dojo

    学习:Dojo入门简易教程 Dojo Toolkit 简介 Dojo 于 2004 年创建,使开发 DHTML 和 JavaScript web 应用程序开发流程更为容易,隐藏了很多现代 web 浏览 ...