Django中FilePathField字段的用法
class FilePathField(path=None[, match=None, recursive=False, max_length=100, **options])
一个 CharField ,内容只限于文件系统内特定目录下的文件名。有三个参数, 其中第一个是 必需的:
FilePathField.path
必填。这个FilePathField 应该得到其选择的目录的绝对文件系统路径。例如: "/home/images".
FilePathField.match
可选的.FilePathField 将会作为一个正则表达式来匹配文件名。但请注意正则表达式将将被作用于基本文件名,而不是完整路径。例如: "foo.*.txt$", 将会匹配到一个名叫 foo23.txt 的文件,但不匹配到 bar.txt 或者 foo23.png.
FilePathField.recursive
可选的.True 或 False.默认是False.声明是否包含所有子目录的路径
FilePathField.allow_files
可选的.True 或 False.默认是True.声明是否包含指定位置的文件。该参数或allow_folders 中必须有一个为 True.
FilePathField.allow_folders
是可选的.输入 True 或者 False.默认值为 False.声明是否包含指定位置的文件夹。该参数或 allow_files 中必须有一个为 True.
当然,这些参数可以同时使用。
有一点需要提醒的是 match只匹配基本文件名(base filename), 而不是整个文件路径(full path). 例如:
FilePathField(path="/home/images", match="foo.*", recursive=True)
...将匹配/home/images/foo.png而不是/home/images/foo/bar.png 因为只允许匹配 基本文件名(foo.png 和 bar.png).
FilePathField实例被创建在您的数据库为varchar列默认最大长度为 100 个字符。作为与其他字段,您可以更改使用的max_length最大长度。
大多数网站在插入图片时一般都是这样处理的:
上传大尺寸图时,自动生成一张缩略图;网页中插入缩略图,并把地址指向大尺寸的图。
所以在Django中,我这样定义主要字段:
title = models.CharField(max_length = 120) img = models.ImageField(upload_to = 'screenshots') thumb = models.FilePathField(path = 'screenshots/thumb')
为什么thumb不是ImageFiled呢?因为考虑到Admin中上传的是大图,而缩略图不是上传,而是自动生成的。所以在这样写。具体的处理是(假设MEDIA_ROOT为/tmp,MEDIA_URL为http://localhost/media/:
上传图片(test.jpg)至MEDIA_ROOT/screenshots,此时img的属性是:img.name = screenshots/test.jpg, img.path = /tmp/screenshots/test.jpg, img.url = http://localhost/media/screenshots/test.jpg
判断图片大小是否需要做缩略图,如果不需要,直接复制img.path到thumb,否则,生成一张缩略图(以test-thumb.jpg命名)保存在screenshots/thumb下。
在网页中插入图片时,就可以简单地用<a href="{% object.img.url %}" rel="external nofollow" ><img title="{% object.title %}" src="{% object.thumb %}" alt="{% object.title %}"></a>来表示了。object表示一个ScreenShot。
补充知识:django FileFIeld和ImageField 上传路径改写
我就废话不多说了,大家还是直接看代码吧!
def get_file_path(instance, filename): return 'file/document/%s/%s/%s' % (instance.period.code, instance.student.college.code, filename) class Document(models.Model): title = models.CharField(max_length=50, blank=True, verbose_name="文档名", default="") student = models.ForeignKey('accounts.Student', verbose_name="学生") period = models.ForeignKey('systemconfig.Periods', verbose_name="阶段") file = models.FileField(upload_to=get_file_path, verbose_name="文档", blank=True, null=True) mark = models.SmallIntegerField(null=True, blank=True, verbose_name="标记") create_time = models.DateTimeField(verbose_name="添加时间", auto_now_add=True) class Meta: verbose_name = "学生报告文档" verbose_name_plural = "学生报告文档" 重点就是get_file_path def get_file_path(instance, filename): return 'file/document/%s/%s/%s' % (instance.period.code, instance.student.college.code, filename) class Document(models.Model): title = models.CharField(max_length=50, blank=True, verbose_name="文档名", default="") student = models.ForeignKey('accounts.Student', verbose_name="学生") period = models.ForeignKey('systemconfig.Periods', verbose_name="阶段") file = models.FileField(upload_to=get_file_path, verbose_name="文档", blank=True, null=True) mark = models.SmallIntegerField(null=True, blank=True, verbose_name="标记") create_time = models.DateTimeField(verbose_name="添加时间", auto_now_add=True) class Meta: verbose_name = "学生报告文档" verbose_name_plural = "学生报告文档"
以上这篇Django中FilePathField字段的用法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
利用 Flask 动态展示 Pyecharts 图表数据方法小结
本文将介绍如何在 web 框架 Flask 中使用可视化工具 pyecharts, 看完本教程你将掌握几种动态展示可视化数据的方法。感兴趣的朋友跟随小编一起看看吧2019-09-09
最新评论