Django中FilePathField字段的用法
class FilePathField(path=None[, match=None, recursive=False, max_length=100, **options])
一個(gè) CharField ,內(nèi)容只限于文件系統(tǒng)內(nèi)特定目錄下的文件名。有三個(gè)參數(shù), 其中第一個(gè)是 必需的:
FilePathField.path
必填。這個(gè)FilePathField 應(yīng)該得到其選擇的目錄的絕對(duì)文件系統(tǒng)路徑。例如: '/home/images'.
FilePathField.match
可選的.FilePathField 將會(huì)作為一個(gè)正則表達(dá)式來匹配文件名。但請(qǐng)注意正則表達(dá)式將將被作用于基本文件名,而不是完整路徑。例如: 'foo.*.txt$', 將會(huì)匹配到一個(gè)名叫 foo23.txt 的文件,但不匹配到 bar.txt 或者 foo23.png.
FilePathField.recursive
可選的.True 或 False.默認(rèn)是False.聲明是否包含所有子目錄的路徑
FilePathField.allow_files
可選的.True 或 False.默認(rèn)是True.聲明是否包含指定位置的文件。該參數(shù)或allow_folders 中必須有一個(gè)為 True.
FilePathField.allow_folders
是可選的.輸入 True 或者 False.默認(rèn)值為 False.聲明是否包含指定位置的文件夾。該參數(shù)或 allow_files 中必須有一個(gè)為 True.
當(dāng)然,這些參數(shù)可以同時(shí)使用。
有一點(diǎn)需要提醒的是 match只匹配基本文件名(base filename), 而不是整個(gè)文件路徑(full path). 例如:
FilePathField(path='/home/images', match='foo.*', recursive=True)
...將匹配/home/images/foo.png而不是/home/images/foo/bar.png 因?yàn)橹辉试S匹配 基本文件名(foo.png 和 bar.png).
FilePathField實(shí)例被創(chuàng)建在您的數(shù)據(jù)庫為varchar列默認(rèn)最大長(zhǎng)度為 100 個(gè)字符。作為與其他字段,您可以更改使用的max_length最大長(zhǎng)度。
大多數(shù)網(wǎng)站在插入圖片時(shí)一般都是這樣處理的:
上傳大尺寸圖時(shí),自動(dòng)生成一張縮略圖;網(wǎng)頁中插入縮略圖,并把地址指向大尺寸的圖。
所以在Django中,我這樣定義主要字段:
title = models.CharField(max_length = 120)img = models.ImageField(upload_to = ’screenshots’)thumb = models.FilePathField(path = ’screenshots/thumb’)
為什么thumb不是ImageFiled呢?因?yàn)榭紤]到Admin中上傳的是大圖,而縮略圖不是上傳,而是自動(dòng)生成的。所以在這樣寫。具體的處理是(假設(shè)MEDIA_ROOT為/tmp,MEDIA_URL為http://localhost/media/:
上傳圖片(test.jpg)至MEDIA_ROOT/screenshots,此時(shí)img的屬性是:img.name = screenshots/test.jpg, img.path = /tmp/screenshots/test.jpg, img.url = http://localhost/media/screenshots/test.jpg
判斷圖片大小是否需要做縮略圖,如果不需要,直接復(fù)制img.path到thumb,否則,生成一張縮略圖(以test-thumb.jpg命名)保存在screenshots/thumb下。
在網(wǎng)頁中插入圖片時(shí),就可以簡(jiǎn)單地用<a href='http://www.aoyou183.cn/bcjs/{% object.img.url %}' rel='external nofollow' ><img src='http://www.aoyou183.cn/bcjs/{% object.thumb %}' alt='{% object.title %}'></a>來表示了。object表示一個(gè)ScreenShot。
補(bǔ)充知識(shí):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='學(xué)生') 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='標(biāo)記') create_time = models.DateTimeField(verbose_name='添加時(shí)間', auto_now_add=True) class Meta: verbose_name = '學(xué)生報(bào)告文檔' verbose_name_plural = '學(xué)生報(bào)告文檔'重點(diǎn)就是get_file_pathdef 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='學(xué)生') 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='標(biāo)記') create_time = models.DateTimeField(verbose_name='添加時(shí)間', auto_now_add=True)class Meta: verbose_name = '學(xué)生報(bào)告文檔'verbose_name_plural = '學(xué)生報(bào)告文檔'
以上這篇Django中FilePathField字段的用法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 如何通過eclipse web項(xiàng)目導(dǎo)入itellij idea并啟動(dòng)2. jsp實(shí)現(xiàn)登錄界面3. PHP未來的一些可能4. IDEA 端口占用的解決方法(推薦)5. 刪除docker里建立容器的操作方法6. 關(guān)于在IDEA中SpringBoot項(xiàng)目中activiti工作流的使用詳解7. 使用vue寫一個(gè)翻頁的時(shí)間插件實(shí)例代碼8. python 服務(wù)器運(yùn)行代碼報(bào)錯(cuò)ModuleNotFoundError的解決辦法9. 使用IDEA編寫jsp時(shí)EL表達(dá)式不起作用的問題及解決方法10. 將Git存儲(chǔ)庫克隆到本地IntelliJ IDEA項(xiàng)目中的詳細(xì)教程
