Как добавить конечную косую черту для приложения для категоризации Django MPTT?

Я использую Django-MPTT для разработки приложения для категоризации для моего проекта Django. Но я не могу получить шаблон регулярного выражения для добавления конечной косой черты, которая также не разбивается на дочерние категории.

Вот пример URL: http://mydjangoapp.com/categories/parentcat/childcat/ Я хотел бы иметь возможность использовать http://mydjangoapp.com/categories/parentcat и перенаправить его в конечную косую черту. То же самое относится к http://mydjangoapp.com/categories/parentcat/childcat (он должен перенаправить на http://mydjangoapp.com/categories/parentcat/childcat/ ).

Вот мой urls.py:

from django.conf.urls.defaults import patterns, include, url from django.views.decorators.cache import cache_page from storefront.categories.models import Category from storefront.categories.views import SimpleCategoryView urlpatterns = patterns('', url(r'^(?P<full_slug>[-\w/]+)', cache_page(SimpleCategoryView.as_view(), 60 * 15), name='category_view'), ) 

И вот мое мнение:

 from django.core.exceptions import ImproperlyConfigured from django.core.urlresolvers import reverse from django.views.generic import TemplateView, DetailView from django.views.generic.detail import SingleObjectTemplateResponseMixin, SingleObjectMixin from django.utils.translation import ugettext as _ from django.contrib.syndication.views import Feed from storefront.categories.models import Category class SimpleCategoryView(TemplateView): def get_category(self): return Category.objects.get(full_slug=self.kwargs['full_slug']) def get_context_data(self, **kwargs): context = super(SimpleCategoryView, self).get_context_data(**kwargs) context["category"] = self.get_category() return context def get_template_names(self): if self.get_category().template_name: return [self.get_category().template_name] else: return ['categories/category_detail.html'] 

И, наконец, моя модель:

 from django.db import models from mptt.models import MPTTModel from mptt.fields import TreeForeignKey class CategoryManager(models.Manager): def get(self, **kwargs): defaults = {} defaults.update(kwargs) if 'full_slug' in defaults: if defaults['full_slug'] and defaults['full_slug'][-1] != "/": defaults['full_slug'] += "/" return super(CategoryManager, self).get(**defaults) class Category(MPTTModel): title = models.CharField(max_length=255) description = models.TextField(blank=True, help_text='Please use <a href="http://daringfireball.net/projects/markdown/syntax">Markdown syntax</a> for all text-formatting and links. No HTML is allowed.') slug = models.SlugField(help_text='Prepopulates from title field.') full_slug = models.CharField(max_length=255, blank=True) template_name = models.CharField(max_length=70, blank=True, help_text="Example: 'categories/category_parent.html'. If this isn't provided, the system will use 'categories/category_detail.html'. Use 'categories/category_parent.html' for all parent categories and 'categories/category_child.html' for all child categories.") parent = TreeForeignKey('self', null=True, blank=True, related_name='children') objects = CategoryManager() class Meta: verbose_name = 'category' verbose_name_plural = 'categories' def save(self, *args, **kwargs): orig_full_slug = self.full_slug if self.parent: self.full_slug = "%s%s/" % (self.parent.full_slug, self.slug) else: self.full_slug = "%s/" % self.slug obj = super(Category, self).save(*args, **kwargs) if orig_full_slug != self.full_slug: for child in self.get_children(): child.save() return obj def available_product_set(self): """ Returns available, prioritized products for a category """ from storefront.apparel.models import Product return self.product_set.filter(is_available=True).order_by('-priority') def __unicode__(self): return "%s (%s)" % (self.title, self.full_slug) def get_absolute_url(self): return '/categories/%s' % (self.full_slug) 

  • Асинхронная URL-схема, когда нам не нужен результат?
  • Преобразовать имя файла в файл: // URL
  • Как предотвратить URL-адрес Scrapy из URL-адреса URL-адреса
  • Сокращение URL-адреса с помощью Python
  • Добавить параметры в заданный URL в Python
  • Как извлечь URL-адреса с HTML-страницы в Python
  • процент кодирования URL-адреса с помощью python
  • Получить переменную из URL-адреса в маршруте Flask
  • 3 Solutions collect form web for “Как добавить конечную косую черту для приложения для категоризации Django MPTT?”

    Это должно соответствовать URL-адресам без косой черты:

     r'^(?P<full_slug>[-\w/]+)/$' 

    Вы можете перенаправить эти совпадения в full_slug + "/".

    Оказывается, мой рисунок был немного. Правильный шаблон в URLConf равен (r'^(?P<full_slug>[-\w/]+/)$'

    Я закончил с этим решением: url(r'^(?P<full_slug>[-\w/]+)'...

    Interesting Posts

    Общий вид 'archive_year' создает пустую страницу

    Как вернуть только пользовательский путь в переменные окружения без доступа к реестру?

    как вызвать / запустить несколько сценариев python из пакетного файла в окне xp / 7

    определить численную оценку производной симплексной функции

    Не удалось найти файл Python.h на CentOS

    Как я могу написать модульные тесты против кода, использующего matplotlib?

    Отмените опцию `–no-site-packages` с virtualenv

    печать медленно (Simulate typing)

    Python: проверка, находится ли точка внутри многоугольника

    Помогите мне разобраться в обходном пути без использования рекурсии

    AttributeError: объект «Менеджер» не имеет атрибута «get_by_natural_key» в Django?

    Есть ли встроенная функция javascript, похожая на os.path.join?

    Найти свободное место на диске в python на OS / X

    Почему я получаю TypeError: не могу умножить последовательность на non-int типа «float»?

    TypeError: объект 'generator' не подлежит расшифровке, csv-файл

    Python - лучший язык программирования в мире.