【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 ...
随机推荐
- java中的几种基础排序
import java.util.Random;import java.util.Arrays; public class Puppy { public static void main(St ...
- 2020 CiGA Game Jam活动总结
CiGA Game Jam 总结 今年8月14.15.16号,48小时游戏开发--Game Jam开始了.蠢新第一次参加Game Jam,今年还是线上开展,情绪复杂= = 还有一个坏消息,晓航旅游缺席 ...
- 线上Redis高并发性能调优实践
项目背景 最近,做一个按优先级和时间先后排队的需求.用 Redis 的 sorted set 做排队队列. 主要使用的 Redis 命令有, zadd, zcount, zscore, zrange ...
- 深入了解Redis(6)-持久化原理
Redis是一个内存数据库,数据保存在内存中.但我们都知道存储在内存中的数据会因为外部因素而丢失,所以Redis会把数据持久化到磁盘中,至于是如何持久化呢? 一.RDB 1.手动触发 save:该命令 ...
- Focal loss论文解析
Focal loss是目标检测领域的一篇十分经典的论文,它通过改造损失函数提升了一阶段目标检测的性能,背后关于类别不平衡的学习的思想值得我们深入地去探索和学习.正负样本失衡不仅仅在目标检测算法中会出现 ...
- DOJO dataGrid 单击单元格选中行
onCellClick: lang.hitch(this, function(event){ //单元格单击事件 var grid = dijit.byId("__geodisa_grid& ...
- Java知识系统回顾整理01基础07类和对象01引用
一.引用的定义 引用的概念,如果一个变量的类型是 类类型,而非基本类型,那么该变量又叫做引用. 二.引用和指向 new Hero(); 代表创建了一个Hero对象 但是也仅仅是创建了一个对象,没有办法 ...
- Arduino 跑马灯
参考: 1. https://blog.csdn.net/hunhun1122/article/details/70254606 2. http://www.51hei.com/arduino/392 ...
- ATMEGA的SPI总线 - 第1部分
转自: 1. https://www.yiboard.com/thread-782-1-1.html 2.https://mansfield-devine.com/speculatrix/2018/0 ...
- SPI通信基础学习
SPI是"Serial Peripheral Interface"的缩写,即"串行外设接口",是摩托罗拉公司推出的一种串行接口通信协议. 接线的示意图: SPI ...