【django-simpleui】‘simpletags‘ is not a registered tag library报错的解决方法
1:创建 templatetags文件夹
2:创建simpletags.py文件将内容粘贴进去,在下面
3:setting.py添加文件指定:
1 TEMPLATES = [
2 {
3 'BACKEND': 'django.template.backends.django.DjangoTemplates',
4 'DIRS': [BASE_DIR+"/templates", ],
5 'APP_DIRS': True,
6 'OPTIONS': {
7 'context_processors': [
8 'django.template.context_processors.debug',
9 'django.template.context_processors.request',
10 'django.contrib.auth.context_processors.auth',
11 'django.contrib.messages.context_processors.messages',
12 ],
13 'libraries': {
14 'simpleui': 'simpleui.templatetags.simpletags', # 添加位置
15 }
16 },
17 },
18 ]
# simpletags.py
import base64
import json
import os
import platform
import sys
import time import django
import simpleui
from django import template from django.core.serializers.json import DjangoJSONEncoder
from django.db import models
from django.urls import reverse
from django.utils.encoding import force_text
from django.utils.functional import Promise
from django.utils.html import format_html
from django.utils.safestring import mark_safe register = template.Library() PY_VER = sys.version[0] # 2 or 3
from django.utils.translation import gettext_lazy as _ if PY_VER != '2':
from importlib import reload def unicode_to_str(u, encoding='utf-8'):
if PY_VER != '2':
return u
return u.encode(encoding) class LazyEncoder(DjangoJSONEncoder):
"""
解决json __proxy__ 问题
""" def default(self, obj):
if isinstance(obj, Promise):
return force_text(obj)
return super(LazyEncoder, self).default(obj) @register.simple_tag(takes_context=True)
def context_test(context):
print(context)
pass # context.get('cl').filter_specs[1].links
@register.simple_tag(takes_context=True)
def load_dates(context):
data = {}
cl = context.get('cl')
if cl.has_filters:
for spec in cl.filter_specs:
# 自定义的filter,没有field
if not hasattr(spec, 'field'):
continue field = spec.field
field_type = None
if isinstance(field, models.DateTimeField):
field_type = 'datetime'
elif isinstance(field, models.DateField):
field_type = 'date'
elif isinstance(field, models.TimeField):
field_type = 'time' if field_type:
data[spec.field_path] = field_type
context['date_field'] = data return '<script type="text/javascript">var searchDates={}</script>'.format(json.dumps(data, cls=LazyEncoder)) @register.filter
def has_filter(spec):
return hasattr(spec, 'parameter_name') @register.filter
def get_date_type(spec):
field = spec.field
field_type = ''
if isinstance(field, models.DateTimeField):
field_type = 'datetime'
elif isinstance(field, models.DateField):
field_type = 'date'
elif isinstance(field, models.TimeField):
field_type = 'time' return field_type @register.filter
def test(obj):
print(obj)
# pass
return '' @register.filter
def to_str(obj):
return str(obj) @register.filter
def date_to_json(obj):
return json.dumps(obj.date_params, cls=LazyEncoder) @register.simple_tag(takes_context=True)
def home_page(context):
'''
处理首页,通过设置判断打开的是默认页还是自定义的页面
:return:
'''
home = __get_config('SIMPLEUI_HOME_PAGE')
if home:
context['home'] = home title = __get_config('SIMPLEUI_HOME_TITLE')
if not title:
title = '首页' icon = __get_config('SIMPLEUI_HOME_ICON')
if not icon:
icon = 'el-icon-menu' context['title'] = title
context['icon'] = icon return '' def __get_config(name):
from django.conf import settings
value = os.environ.get(name, getattr(settings, name, None)) return value @register.filter
def get_config(key):
return __get_config(key) @register.simple_tag
def get_version():
return simpleui.get_version() @register.simple_tag
def get_app_info():
return format_table({"version": simpleui.get_version()}) def format_table(d):
html = '<table class="simpleui-table"><tbody>'
for key in d:
html += '<tr><th>{}</th><td>{}</td></tr>'.format(key, d.get(key))
html += '</tbody></table>'
return format_html(html) @register.simple_tag(takes_context=True)
def menus(context, _get_config=None):
data = [] # return request.user.has_perm("%s.%s" % (opts.app_label, codename))
if not _get_config:
_get_config = get_config config = _get_config('SIMPLEUI_CONFIG')
if not config:
config = {} if config.get('dynamic', False) is True:
config = _import_reload(_get_config('DJANGO_SETTINGS_MODULE')).SIMPLEUI_CONFIG app_list = context.get('app_list')
for app in app_list:
_models = [
{
'name': m.get('name'),
'icon': get_icon(m.get('object_name'), unicode_to_str(m.get('name'))),
'url': m.get('admin_url'),
'addUrl': m.get('add_url'),
'breadcrumbs': [{
'name': app.get('name'),
'icon': get_icon(app.get('app_label'), app.get('name'))
}, {
'name': m.get('name'),
'icon': get_icon(m.get('object_name'), unicode_to_str(m.get('name')))
}]
} for m in app.get('models')
] if app.get('models') else [] module = {
'name': app.get('name'),
'icon': get_icon(app.get('app_label'), app.get('name')),
'models': _models
}
data.append(module) # 如果有menu 就读取,没有就调用系统的
key = 'system_keep'
if config and 'menus' in config:
if config.get(key, None):
temp = config.get('menus')
for i in temp:
# 处理面包屑
if 'models' in i:
for k in i.get('models'):
k['breadcrumbs'] = [{
'name': i.get('name'),
'icon': i.get('icon')
}, {
'name': k.get('name'),
'icon': k.get('icon')
}]
else:
i['breadcrumbs'] = [{
'name': i.get('name'),
'icon': i.get('icon')
}]
data.append(i)
else:
data = config.get('menus') # 获取侧边栏排序, 如果设置了就按照设置的内容排序, 留空则表示默认排序以及全部显示
if config.get('menu_display') is not None:
display_data = list()
for _app in data:
if _app['name'] not in config.get('menu_display'):
continue
_app['_weight'] = config.get('menu_display').index(_app['name'])
display_data.append(_app)
display_data.sort(key=lambda x: x['_weight'])
data = display_data # 给每个菜单增加一个唯一标识,用于tab页判断
eid = 1000
for i in data:
eid += 1
i['eid'] = eid
if 'models' in i:
for k in i.get('models'):
eid += 1
k['eid'] = eid return '<script type="text/javascript">var menus={}</script>'.format(json.dumps(data, cls=LazyEncoder)) def get_icon(obj, name=None):
temp = get_config_icon(name)
if temp != '':
return temp _dict = {
'auth': 'fas fa-shield-alt',
'User': 'far fa-user',
'Group': 'fas fa-users-cog'
}
temp = _dict.get(obj)
if not temp:
_default = __get_config('SIMPLEUI_DEFAULT_ICON')
if _default is None or _default:
return 'far fa-circle'
return ''
return temp # 从配置中读取图标
def get_config_icon(name):
_config_icon = __get_config('SIMPLEUI_ICON')
if _config_icon is None:
return '' if name in _config_icon:
return _config_icon.get(name)
return '' @register.simple_tag(takes_context=True)
def load_message(context):
messages = context.get('messages')
array = [dict(msg=msg.message, tag=msg.tags) for msg in messages] if messages else [] return '<script id="out_message" type="text/javascript">var messages={}</script>'.format(
json.dumps(array, cls=LazyEncoder)) @register.simple_tag(takes_context=True)
def context_to_json(context):
json_str = '{}' return mark_safe(json_str) @register.simple_tag()
def get_language():
from django.conf import settings
return settings.LANGUAGE_CODE.lower() @register.filter
def get_language_code(val):
from django.conf import settings
return settings.LANGUAGE_CODE.lower() def get_analysis_config():
val = __get_config('SIMPLEUI_ANALYSIS')
if val:
return True
return False @register.simple_tag(takes_context=True)
def load_analysis(context):
try:
if not get_analysis_config():
return '' # 理论上值一天只上报一次
key = 'simpleui_' + time.strftime('%Y%m%d', time.localtime()) if key in context.request.session:
return '' b64 = ""
j = {
"n": platform.node(),
"o": platform.platform(),
"p": platform.python_version(),
"d": django.get_version(),
"s": simpleui.get_version(),
}
if 'theme_name' in context.request.COOKIES:
j['t'] = context.request.COOKIES['theme_name']
else:
j['t'] = 'Default' b64 = base64.b64encode(str(j).encode('utf-8')) url = '//simpleui.88cto.com/analysis'
b64 = b64.decode('utf-8')
html = '<script async type="text/javascript" src="{}/{}"></script>'.format(url, b64);
context.request.session[key] = True return mark_safe(html)
except:
return '' @register.simple_tag(takes_context=True)
def custom_button(context):
admin = context.get('cl').model_admin
data = {}
actions = admin.get_actions(context.request)
# if hasattr(admin, 'actions'):
# actions = admin.actions
# 输出自定义按钮的属性 if actions:
i = 0
for name in actions:
values = {}
fun = actions.get(name)[0]
for key, v in fun.__dict__.items():
if key != '__len__' and key != '__wrapped__':
values[key] = v
values['eid'] = i
i += 1
data[name] = values return json.dumps(data, cls=LazyEncoder) from django.db.models.fields.related import ForeignKey def get_model_fields(model, base=None):
field_list = []
fields = model._meta.fields
for f in fields:
label = f.name
if hasattr(f, 'verbose_name'):
label = getattr(f, 'verbose_name') if isinstance(label, Promise):
label = str(label) if base:
field_list.append(('{}__{}'.format(base, f.name), label))
else:
field_list.append((f.name, label)) return field_list @register.simple_tag(takes_context=True)
def search_placeholder(context):
cl = context.get('cl') # 取消递归,只获取2级
fields = get_model_fields(cl.model) for f in cl.model._meta.fields:
if isinstance(f, ForeignKey):
fields.extend(get_model_fields(f.related_model, f.name)) verboses = [] for s in cl.search_fields:
for f in fields:
if f[0] == s:
verboses.append(f[1])
break return ",".join(verboses) def _import_reload(_modules):
_obj = __import__(_modules, fromlist=_modules.split('.'))
reload(_obj)
return _obj @register.simple_tag
def get_tz_suffix():
# 判断settings.py中的TZ是否为false
tz = __get_config('USE_TZ')
# 必须明确指定为True的时候,才返回+8 的后缀
if tz:
return '+08:00'
return '' @register.simple_tag
def simple_version():
return simpleui.get_version() @register.simple_tag(takes_context=True)
def get_model_url(context):
# reverse()
opts = context.get('opts')
key = 'admin:{}_{}_changelist'.format(opts.app_label, opts.model_name)
return reverse(key) @register.simple_tag
def has_enable_admindoc():
from django.conf import settings
apps = settings.INSTALLED_APPS
return 'django.contrib.admindocs' in apps @register.simple_tag(takes_context=True)
def has_admindoc_page(context):
if hasattr(context, 'template_name'):
return context.template_name.find('admin_doc') == 0
return False @register.simple_tag
def get_boolean_choices():
return (
('True', _('Yes')),
('False', _('No'))
) @register.simple_tag(takes_context=True)
def get_previous_url(context):
return context.request.META.get('HTTP_REFERER') if __name__ == "__main__":
pass
【django-simpleui】‘simpletags‘ is not a registered tag library报错的解决方法的更多相关文章
- django正常运行确报错的解决方法
django正常运行却报错的处理方法 出处 : https://www.infvie.com/ops-notes/django-normal-operation-error 报错一:self._soc ...
- django报错信息解决方法
You have 17 unapplied migration(s). Your project may not work properly until you apply the migration ...
- Django+python报错与解决方法
编码信息导致修改django文件下的debug.py文件331行的编码格式 with Path(CURRENT_DIR, 'templates', 'technical_500.html').open ...
- django.template.exceptions.TemplateSyntaxError: 'article_tags' is not a registered tag library.
django.template.exceptions.TemplateSyntaxError: 'article_tags' is not a registered tag library. Must ...
- django.template.exceptions.TemplateSyntaxError: 'static' is not a registered tag library. Must be one of:
在访问web页面时报错,详细日志如下: django.template.exceptions.TemplateSyntaxError: 'staticfiles' is not a registere ...
- 关于'selffilter' is not a registered tag library. Must be one of:
报错代码: 'selffilter' is not a registered tag library. Must be one of: admin_list admin_modify admin_st ...
- Django 自定义模板标签 报错django.template.exceptions.TemplateSyntaxError: '####' is not a registered tag library. Must be one of:
我写代码遇到这个错误,但是发现程序没有写错,好像是程序有缓存,重新运行几次就好了. 自定义模板标签,可以不用写views,url直接通过自定义函数把变量传给模板. 具体实现: 1.在app下新建Pyt ...
- 08:'my_tag' is not a registered tag library. Must be one of
确保每次修改模板标签时都重新启动 Django 开发服务器(或确保它自己重新启动).如果服务器没有重新启动,Django 将不会注册标签. 从 django 1.9 开始,您可以在如下设置中加载这些新 ...
- Django | 模型类变更后生成迁移文件,报错:You are trying to add a non-nullable field 'BookName' to BookInfo without a default....
报错: You are trying to add a non-nullable field 'BookName' to BookInfo without a default; we can't do ...
随机推荐
- zabbix_server.conf配置文件参数
NodeID: 在amster-child 的分布式架构中,这个ID是唯一标识zabbix node的号码 ListenPort:Trapper 类型Item监听的端口, SourceIP: 在连接其 ...
- IntelliJ IDEA 2020.2 x64 最新破解教程有效期到2089年 完全免费分享
作者:极客小俊 一个专注于web技术的80后 我不用拼过聪明人,我只需要拼过那些懒人 我就一定会超越大部分人! CSDN@极客小俊,原创文章, B站技术分享 B站视频 : Bilibili.com 个 ...
- Linux服务器内存监控—每小时检查&超出发送邮件&重启占用最高的Java程式
简介与优点 使用该脚本能自行判断系统内存使用情况是否超出设定百分比 能在超出预警值时执行重启程式的操作 能记录重启过程,并将具体LOG邮件发送给指定收信人 可以设定Crontab排程,达成每隔一段时间 ...
- Metasploit之后渗透攻击(信息收集、权限提升)
利用永恒之蓝漏洞入侵Windows7 流程参考https://www.jianshu.com/p/03a1c13f963a,实在是太棒啦!!! 目标主机为win7(IP:192.168.1.102): ...
- 简述application.properties和application.yml 以及 @ConfigurationProperties 和@PropertySource @Value 和@ImportResource的用法,区别
问题: 如何在application.properties和application.yml中配置String,Date,Object,Map,List类型的属性,并且idea能提示 先写一个Perso ...
- [VBA原创源代码] excelhome 对花名册进行分类
最近在学习<菜鸟谈VBA最最基础入门<原创>>,其中第22节有一个VBA编程作业,实现对花名册进行分类. 自己花了点时间,自己丫丫学步,终于实现出来. 在原创聚集地cnblog ...
- Dell XPS 7590 Hackintosh
网上主流引导Hackintosh的工具有Chameleon, Clover和OpenCore. 但是随着Hackintosh重要驱动开发团队acidanthera逐渐转向OpenCore,后者显然才是 ...
- C++有子对象的派生类的构造函数
转载:https://blog.csdn.net/qq1169091731/article/details/50934588?utm_source=blogxgwz6 类的数据成员不但可以是标准型(如 ...
- Android作业10/07
1.多个Activity界面实现数据的传递 <?xml version="1.0" encoding="utf-8"?> <androidx. ...
- springCloud项目搭建
新建父maven项目 groupId:pers.xzp.springCloudartifactId:springCloud 父项目中仅仅需要一个pom文件,用于管理模块的依赖统一.继承等 编辑pom文 ...