Използвам Django-Compressor Filter като част от Wagtail (CMS вариант на Django със супер страхотен потребителски интерфейс). Средата е Wagtail 0.2 + Python 2.7 + Django 1.6 + Virtualenv + FastCGI + Apache споделен хостинг.
Проблем възниква при опит за достъп до страницата за администратор/вход на CMS. Django показва шаблон за изобразяване на грешка
Error during template rendering
In template /home/username/env/lib/python2.7/site-packages/wagtail/wagtailadmin/templates/wagtailadmin/skeleton.html, error at line 20
/bin/sh: django_libsass.SassCompiler: command not found
Ред 20 на skeleton.html е:
<!doctype html>
{% load compress %}
<!--[if lt IE 7]> <html class="no-js lt-ie9 lt-ie8 lt-ie7" lang="{{ LANGUAGE_CODE|default:"en-gb" }}"> <![endif]-->
<!--[if IE 7]> <html class="no-js lt-ie9 lt-ie8" lang="{{ LANGUAGE_CODE|default:"en-gb" }}"> <![endif]-->
<!--[if IE 8]> <html class="no-js lt-ie9" lang="{{ LANGUAGE_CODE|default:"en-gb" }}"> <![endif]-->
<!--[if gt IE 8]><!--> <html class="no-js" lang="{{ LANGUAGE_CODE|default:"en-gb" }}"> <!--<![endif]-->
<title>Wagtail - {% block titletag %}{% endblock %}</title>
<meta name="description" content="" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<script src="//cdnjs.cloudflare.com/ajax/libs/modernizr/2.6.2/modernizr.min.js"></script>
{% block css %}{# Block defined for timing breakdowns in django debug toolbar - not expected to be overridden #}
<link rel="stylesheet" href="/bg//fonts.googleapis.com/css?family=Open+Sans:300,400,600,700" />
<link rel="stylesheet" href="/bg//fonts.googleapis.com/css?family=Bitter:400,700" />
19
20 {% compress css %}
21 <link rel="stylesheet" href="/bg{{ STATIC_URL }}wagtailadmin/scss/normalize.css" />
<link rel="stylesheet" href="/bg{{ STATIC_URL }}wagtailadmin/scss/vendor/jquery-ui/jquery-ui-1.10.3.verdant.css" />
<link rel="stylesheet" href="/bg{{ STATIC_URL }}wagtailadmin/scss/vendor/jquery.timepicker.css" />
<link rel="stylesheet" href="/bg{{ STATIC_URL }}wagtailadmin/scss/core.scss" type="text/x-scss" />
{% endcompress %}
{% block extra_css %}{% endblock %}
{% endblock %}
</head>
<body class="{% block bodyclass %}{% endblock %} {% if messages %}has-messages{% endif %}">
предкомпилатора в моя settings.py, DEBUG е зададен на True:
COMPRESS_ENABLED = True
COMPRESS_PRECOMPILERS = (
('text/x-scss', 'django_libsass.SassCompiler'),
)
ОПИТ И ГРЕШКА №1
Опитах да променя на:
('text/x-scss', '/home/username/env/lib/python2.7/site-packages/django_libsass {infile} {outfile}')
но това ме води до грешка в елемент на последователност за актуализиране на речника #0.
Имам инсталиран django_libsass & компресор, също опитах pip install libsass
, ngm install lessc
, pip install sass
, обръщайки DEBUG = False
, добавяйки COMPRESSOR_OFFLINE
, добавяйки COMPRESSOR_ENABLED
, както е предложено в други подобни въпроси. Изпълнението на manage.py compress
връща същата грешка.
Проверих отново и сайт-пакетите и django_libsass наистина са на моя sys.path
SassCompiler може да бъде намерен в ~/env/lib/python2.7/site-packages/django_libsass.py
ОПИТ И ГРЕШКА №2
Проверих отново дали sass
е инсталиран и на моя път.
Променете кода на:
COMPRESS_PRECOMPILERS = (
('text/x-scss', 'sass --scss {infile} {outfile}'),
)
Връща грешка:
Exception Type: FilterError
Exception Value:
/bin/sh: sass: command not found
ОПИТ И ГРЕШКА №3
След като прочетох този проблем с feedly, опитах pip install compass
без ефект
ОПИТ И ГРЕШКА #4
След коментара на gasman стартирах обвивката на python manage.py и се опитах да импортирам SassCompiler. Работи без грешки.
Python 2.7.6 (default, Nov 11 2013, 18:34:29)
[GCC 4.4.7 20120313 (Red Hat 4.4.7-3)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
(InteractiveConsole)
>>> from django_libsass import SassCompiler
>>>
Пълно проследяване
Извинявам се, ако този въпрос става твърде дълъг.
Traceback:
File "/home/username/env/lib/python2.7/site-packages/django/core/handlers/base.py" in get_response
139. response = response.render()
File "/home/username/env/lib/python2.7/site-packages/django/template/response.py" in render
105. self.content = self.rendered_content
File "/home/username/env/lib/python2.7/site-packages/django/template/response.py" in rendered_content
82. content = template.render(context)
File "/home/username/env/lib/python2.7/site-packages/django/template/base.py" in render
140. return self._render(context)
File "/home/username/env/lib/python2.7/site-packages/django/template/base.py" in _render
134. return self.nodelist.render(context)
File "/home/username/env/lib/python2.7/site-packages/django/template/base.py" in render
840. bit = self.render_node(node, context)
File "/home/username/env/lib/python2.7/site-packages/django/template/debug.py" in render_node
78. return node.render(context)
File "/home/username/env/lib/python2.7/site-packages/django/template/loader_tags.py" in render
123. return compiled_parent._render(context)
File "/home/username/env/lib/python2.7/site-packages/django/template/base.py" in _render
134. return self.nodelist.render(context)
File "/home/username/env/lib/python2.7/site-packages/django/template/base.py" in render
840. bit = self.render_node(node, context)
File "/home/username/env/lib/python2.7/site-packages/django/template/debug.py" in render_node
78. return node.render(context)
File "/home/username/env/lib/python2.7/site-packages/django/template/loader_tags.py" in render
62. result = block.nodelist.render(context)
File "/home/username/env/lib/python2.7/site-packages/django/template/base.py" in render
840. bit = self.render_node(node, context)
File "/home/username/env/lib/python2.7/site-packages/django/template/debug.py" in render_node
78. return node.render(context)
File "/home/username/env/lib/python2.7/site-packages/compressor/templatetags/compress.py" in render
147. return self.render_compressed(context, self.kind, self.mode, forced=forced)
File "/home/username/env/lib/python2.7/site-packages/compressor/templatetags/compress.py" in render_compressed
107. rendered_output = self.render_output(compressor, mode, forced=forced)
File "/home/username/env/lib/python2.7/site-packages/compressor/templatetags/compress.py" in render_output
119. return compressor.output(mode, forced=forced)
File "/home/username/env/lib/python2.7/site-packages/compressor/css.py" in output
51. ret.append(subnode.output(*args, **kwargs))
File "/home/username/env/lib/python2.7/site-packages/compressor/css.py" in output
53. return super(CssCompressor, self).output(*args, **kwargs)
File "/home/username/env/lib/python2.7/site-packages/compressor/base.py" in output
246. content = self.filter_input(forced)
File "/home/username/env/lib/python2.7/site-packages/compressor/base.py" in filter_input
194. for hunk in self.hunks(forced):
File "/home/username/env/lib/python2.7/site-packages/compressor/base.py" in hunks
169. precompiled, value = self.precompile(value, **options)
File "/home/username/env/lib/python2.7/site-packages/compressor/base.py" in precompile
226. **kwargs)
File "/home/username/env/lib/python2.7/site-packages/django_libsass.py" in input
51. return compile(filename=self.filename)
File "/home/username/env/lib/python2.7/site-packages/django_libsass.py" in compile
41. return sass.compile(**kwargs)
Exception Type: AttributeError at /admin/login/
Exception Value: 'module' object has no attribute 'compile'
from django_libsass import SassCompiler
в рамките наmanage.py shell
? - person gasman   schedule 22.03.2014sass.compile
. Притеснявах се, че моят sass не е правилно инсталиран след отговора на Кевин и накарах моя хостинг да го преинсталира & cython & libsass & compass. Опитах същоgem install sass
, което ми дава ruby папка с sass. Преди това имах sass.so в моята папка site-packages. - person moshushi   schedule 22.03.2014'module' object has no attribute 'compile'
е различна от тази, за която първоначално съобщихте, така че изглежда, че нещо се е променило в настройката ви: сега успешно намира django_libsass, но изглежда, че импортира грешното нещо за името „sass“. Моля, опитайте да деинсталирате всички Python пакети, свързани със sass, с изключение на libsass и django-libsass. Ако това няма значение, моля, стартирайтеimport sass; sass
в рамките наmanage.py shell
и ме уведомете какво казва изходът. - person gasman   schedule 23.03.2014import sass; sass
посочиsass.pyc
, но все още даваше същата грешка на атрибута. Изтриването на всички свързани с sass.pyc
файлове реши това и виждам страницата за влизане за първи път! - person moshushi   schedule 23.03.2014/bin/sh: django_libsass.SassCompiler
, която получавах. Сложихshell = False
вbase.py
на компресорния филтър, надявам се, че това няма да създаде проблеми по-нататък - person moshushi   schedule 23.03.2014shell = False
не би трябвало да има значение... сега, когато django-libsass е правилно инсталиран, този ред от код (да се надяваме) никога не трябва да се изпълнява. - person gasman   schedule 24.03.2014