This takes the "easier to ask forgiveness than permission" approach to making sure your model's slug is unique.
If the model's slug is empty, make a slug from the model's 'name' field.
We assume that it is a conflicting slug that is throwing the IntegrityError, in which case if the slug does not end with '-' followed by a number then append '-2'. If the slug does end with '-' followed by a number then capture that final number, increment it by one, save the new slug value and try savin g again.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
from django.db import models, IntegrityError class MyModel(models.Model): def save(self): """Auto-populate an empty slug field from the MyModel name and if it conflicts with an existing slug then append a number and try saving again. """ import re from django.template.defaultfilters import slugify if not self.slug: self.slug = slugify(self.name) # Where self.name is the field used for 'pre-populate from' while True: try: super(MyModel, self).save() # Assuming the IntegrityError is due to a slug fight except IntegrityError: match_obj = re.match(r'^(.*)-(\d+)$', self.slug) if match_obj: next_int = int(match_obj.group(2)) + 1 self.slug = match_obj.group(1) + '-' + str(next_int) else: self.slug += '-2' else: break
More like this
- codigo alto nivel by MrRocklion 3 days, 5 hours ago
- Load template from specific app by Krzysiek555 3 weeks, 2 days ago
- PostgreSQL JSON subqueries by dolamroth 3 weeks, 4 days ago
- "Magic Link" Management Command by webology 6 months ago
- Closest ORM models to a latitude/longitude point by simonw 6 months ago