2012-03-27 6 views
6

Django Unicode Slug jak?Jak sprawić, by Django tworzyło ślimaki ze znaków Unicode?

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, }) 
+0

możliwy duplikat [Jak zrobić prace Django slugify poprawnie z ciągów Unicode?] (Http: // stackoverflow. com/questions/702337/how-to-make-django-slugify-work-properly-with-unicode-string) –

+0

To działa w moim przypadku. http://pypi.python.org/pypi/Unidecode. http://stackoverflow.com/a/4036665/489943. Dzięki. Odpowiadasz tutaj. – Ankhaa

+0

możliwy duplikat [Jak utworzyć ślimak w Django?] (Http://stackoverflow.com/questions/837828/how-do-i-create-a-slug-in-django) –

Odpowiedz

6

Django jest wyposażony w funkcję, która:

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

Ale tak naprawdę lepiej jest, używając parametru prepopulated_fields i SlugField.

EDIT:

Wydaje się, że duplikat pytanie, a odpowiedź z propozycją zawartą w drugiej OP działa całkiem dobrze. Najpierw zainstaluj unidecode, a następnie:

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

Możesz przekazać go do późniejszego osuszenia.

Jeśli szukasz ślimaki Unicode caractèers, można użyć mozilla/unicode-slugify

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

Wynik jest http://example.com/news/сайн-уу

+1

Bardzo interesujące. To się sprawdza. Ale to są mongolskie znaki Unicode. nie używaj slugify (u "Сайн уу") – Ankhaa

+0

Ok, slugify używa unicodedata.normalize ('NFKD', u "Сайн уу") .Koduj ('ascii', 'ignore'), aby znormalizować ciąg, ale może nie ma mapowanie między znakami mogolskimi a ascii. Musisz więc utworzyć własne mapowanie i użyć maketrans (http://docs.python.org/library/string.html#string.maketrans), zanim przekażesz je do powracania. –

+0

Wydaje się, że tryb Unidecode robi to bardzo dobrze. Zaktualizowałem odpowiedź. –

1

Zakładając chcesz automatycznie utworzyć ślimak na podstawie tytule NewsModel „s, którego chcesz użyć 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) 
+2

Domyślne slugify django nie obsługuje ciągi znaków Unicode. Przykład slugify (u "Сайн уу") – Ankhaa

+4

slugify + unicode: http://stackoverflow.com/questions/702337/how-to-make-django-slugify-work-properly-with-unicode-strings –

+0

@ TimmyO'Mahony masz na myśli 'unidecode' (nie' unicode') – user3479125

0

To właśnie używam w moich projektach. Wiem, że to pytanie jest wiele razy temu, ale mam nadzieję, że moje rozwiązanie pomoże komuś. powinienem wspomnieć, że nie jest dobrym rozwiązaniem dla tego w https://github.com/mozilla/unicode-slugify ale to co mam użyć:

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) 
Powiązane problemy