Django 中的 Slug
本篇文章旨在定义一个 slug 以及我们如何使用 slug 字段在 Python 中使用 Django 获得独特的帖子。
使用 Slug 在 Django 中获得独特的帖子
对于我们的实际帖子本身,一个 slug 会更容易分享。
比如我们触发http://127.0.0.1:8000/post/pa-roate-10,我们可以这样走,但是这样看起来不太好。 这就是为什么它在 Django 中引入了 slug 的概念。
如果我们有 Django Slug 标题,我们可以将其设为 http://127.0.0.1:8000/post/Djangoslug 而不是上面那个。 然后我们可以使用帖子标题触发我们的帖子。
我们可以做的另一件事是,我们可以使用 - 代替空格,并将其转换为小写。 假设这是我们的标题 Django Slug,如果我们用 - 将其转换为小写,我们就有了 django-slug。
在 Django 中使用 Slug 字段
现在,让我们看看如何在 Django 中使用 slug 字段。 我们可以将 slug 传递给位于大号 (>
) 和小号 (<
) 符号之间的 URL。
我们可以用特定的数据类型来指定它。 views.categoryview()
从 views.py 文件中调用一个函数,然后该函数将呈现 HTML 内容。
urlpatterns = [
path('category/<str:cats>/', views.categoryview(), name='category'),
]
让我们进入我们的 model.py 文件并使用 models.SlugField()
调用一个 slug。 然后我们将 True 传递给唯一参数。
这是一个必填字段。 由于我们设置了 unique=True,我们在数据库中设置了具有唯一名称的帖子标题。
slug = models.SlugField(max_length=100, unique=True)
所以在我们的 models.py 文件中,我们可以创建一个信号,它会在保存之前做一些事情。 我们需要使用以下代码导入信号。
from django.db.models.signals import pre_save
要将我们的标题变成 slug,我们需要导入 slugify 类。 所以我们的标题 Django Slug 将变成 django-slug。
from django.template.defaultfilters import slugify
让我们定义一个函数作为信号接收器。 我们需要传递发件人、实例、参数和关键字参数。
在这个定义的函数中,首先,我们获取 slug 并确保 slug 不存在。 我们将通过过滤器检查它是否存在。
我们将 slug 写成等于这样的字符串“ %s-%s ” 。 这将是实例 ID,因此我们可以通过调用它来获取原始 slug。
def pre_save_post_reciever(sender,instance,*args,**kwargs):
slug=slugify(instance.title)
exists=post.objects.filter().exists()
if exists:
skug="%s-%s"%(slug,instance.id)
instance.slug=slug
pre_save.connect(pre_save_post_reciever,sender=post)
每次调用 pre_save()
方法时,它都会在保存之前执行此操作。 pre_save_post_reciever()
函数将相应地更新我们的 slug。
from django.db.models.signals import pre_save
from django.dispatch import receiver
from django.template.defaultfilters import slugify
def pre_save_post_reciever(sender,instance,*args,**kwargs):
slug=slugify(instance.title)
exists=post.objects.filter().exists()
if exists:
skug="%s-%s"%(slug,instance.id)
instance.slug=slug
pre_save.connect(pre_save_post_reciever,sender=post)
相关文章
Pandas DataFrame DataFrame.shift() 函数
发布时间:2024/04/24 浏览次数:133 分类:Python
-
DataFrame.shift() 函数是将 DataFrame 的索引按指定的周期数进行移位。
Python pandas.pivot_table() 函数
发布时间:2024/04/24 浏览次数:82 分类:Python
-
Python Pandas pivot_table()函数通过对数据进行汇总,避免了数据的重复。
Pandas read_csv()函数
发布时间:2024/04/24 浏览次数:254 分类:Python
-
Pandas read_csv()函数将指定的逗号分隔值(csv)文件读取到 DataFrame 中。
Pandas 多列合并
发布时间:2024/04/24 浏览次数:628 分类:Python
-
本教程介绍了如何在 Pandas 中使用 DataFrame.merge()方法合并两个 DataFrames。
Pandas loc vs iloc
发布时间:2024/04/24 浏览次数:837 分类:Python
-
本教程介绍了如何使用 Python 中的 loc 和 iloc 从 Pandas DataFrame 中过滤数据。
在 Python 中将 Pandas 系列的日期时间转换为字符串
发布时间:2024/04/24 浏览次数:894 分类:Python
-
了解如何在 Python 中将 Pandas 系列日期时间转换为字符串