django | 自动提取文章内的第一张图片为缩略图

本人应为用的是django自带的admin后台,是在admin.py中实现的功能

from .models import News

@admin.register(News)
class GroupAdmin(admin.ModelAdmin):
    list_display = ('title', 'first_time')

    def save_model(self, request, obj, form, change):
        """
        save_model是ModelAdmin下面的一个函数
        :param request: 参数不要改
        :param obj: 参数不要改
        :param form: 参数不要改
        :param change:参数不要改
        :return:
        """
        # 当用户保存景点时,自动填充缩略图字段
        # 自动填充缩略图pic字段,自动提取第一张图片作为缩略图
        # 提取正文中的所有图片,并以列表的形式返回。如果正文没有图片,返回一个空列表。
        pattern = r"""src=["'](.*?)["']"""
        pic_url = re.findall(pattern, obj.news_text)
        if len(pic_url) > 0:  # 正文中有图片,默认提取第一张
            # re.findall()通常匹配出来的是列表,所以要通过索引的方式将内容提取出来。
            obj.pic = pic_url[0]
        else:  # 正文中没有图片,设置默认图片为缩略图
            obj.pic = '/media/default.jpg'
        # 单击django后台的“保存”按钮时,将数据更新到数据库中,不啊哟修改
        super().save_model(request, obj, form, change)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django可以通过Pillow库来生成图片缩略图。以下是一个简单的示例代码: ```python from PIL import Image from django.db import models from django.utils.safestring import mark_safe from django.utils.html import format_html class MyModel(models.Model): image = models.ImageField(upload_to='images') def thumb(self): if self.image: thumb_url = self.image.url + '?width=100&height=100' return format_html('<img src="{}">', thumb_url) else: return '(No image)' thumb.short_description = 'Thumbnail' def save(self, *args, **kwargs): super(MyModel, self).save(*args, **kwargs) if self.image: thumb_path = self.image.path + '.thumb' thumb_size = (100, 100) try: with Image.open(self.image.path) as im: im.thumbnail(thumb_size) im.save(thumb_path, 'JPEG') except IOError: pass ``` 在上述代码中,我们通过Pillow库来生成图片缩略图,并添加了一个thumb方法,用于在Django Admin中显示缩略图。同时,在保存模型时,也会自动图片生成缩略图并保存。 在模板中,我们可以通过{{ object.image.url }}来获取原始图片的URL,通过{{ object.image.url }} + '?width=100&height=100'来获取缩略图的URL,然后将其放入img标签中即可。 ```html {% if object.image %} <img src="{{ object.image.url }}?width=100&height=100"> {% else %} (No image) {% endif %} ``` 需要注意的是,为了避免文件名冲突,我们在生成缩略图时,将其保存在原始图片的文件名后面添加了一个.thumb的后缀。同时,我们也可以根据需要调整缩略图的大小。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值