Как заставить Django создавать пули из символов Unicode?

Django Unicode Slug как?

class NewsModel(models.Model):
 title = models.CharField(max_length = 300)
 slug = models.CharField(max_length = 300)
 content = models.TextField()
 def save(self,*args, **kwargs):
 if self.slug is None:
 self.slug = ???
 super(NewsModel, self).save(*args, **kwargs)
 def get_absolute_url(self):
 return reverse("news_view", kwargs = {"slug" : self.slug, } )
3 ответа

Django имеет функцию для этого:

In [11]: from django.template.defaultfilters import slugify
In [13]: slugify(u'ç é YUOIYO ___ 89098')
Out[13]: u'c-e-yuoiyo-___-89098'

Но на самом деле вам лучше использовать параметр prepopulated_fields и SlugField.

ИЗМЕНИТЬ:

Кажется, это повторяющийся вопрос, и ответ, предложенный в другом OP, работает достаточно хорошо. Сначала установите unidecode, затем:

In [2]: import unidecode
In [3]: unidecode.unidecode(u"Сайн уу")
Out[3]: 'Sain uu

Вы можете передать его, чтобы выполнить slugify после.

Если вы ищете пули южнокодовых каракулеров, вы можете использовать mozilla/unicode-slugify

In [1]: import slugify
In [2]: slugify.slugify(u"Сайн уу")
Out[3]: u'\u0441\u0430\u0439\u043d-\u0443\u0443'

Результат http://example.com/news/сайн-уу


Предполагая, что вы хотите автоматически создать пул на основе заголовка NewsModel, вы хотите использовать slugify:

from django.template.defaultfilters import slugify
def save(self,*args, **kwargs):
 if self.slug is None:
 self.slug = slugify(self.title)
 super(NewsModel, self).save(*args, **kwargs)


Это то, что я использую в своих проектах. Я знаю этот вопрос много раз, но я надеюсь, что мое решение поможет кому-то. я должен упомянуть, что для этого есть хорошее решение в https://github.com/mozilla/unicode-slugify, но это то, что я использую:

import re
import unicodedata
try:
 from django.utils.encoding import smart_unicode as smart_text
except ImportError:
 from django.utils.encoding import smart_text
def slugify(value):
 #underscore, tilde and hyphen are alowed in slugs
 value = unicodedata.normalize('NFKC', smart_text(value))
 prog = re.compile(r'[^~\w\s-]', flags=re.UNICODE)
 value = prog.sub('', value).strip().lower()
 return re.sub(r'[-\s]+', '-', value)

licensed under cc by-sa 3.0 with attribution.