亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Django中FilePathField字段的用法

 更新時(shí)間:2020年05月21日 08:47:03   作者:菲宇  
這篇文章主要介紹了Django中FilePathField字段的用法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧

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)該得到其選擇的目錄的絕對文件系統(tǒng)路徑。例如: "/home/images".

FilePathField.match

可選的.FilePathField 將會(huì)作為一個(gè)正則表達(dá)式來匹配文件名。但請注意正則表達(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)最大長度為 100 個(gè)字符。作為與其他字段,您可以更改使用的max_length最大長度。

大多數(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í),就可以簡單地用<a href="{% object.img.url %}" rel="external nofollow" ><img title="{% object.title %}" src="{% object.thumb %}" alt="{% object.title %}"></a>來表示了。object表示一個(gè)ScreenShot。

補(bǔ)充知識: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_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="學(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字段的用法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論