鍍金池/ 教程/ Python/ 文件儲(chǔ)存API
編寫自定義存儲(chǔ)系統(tǒng)
高級(jí)
編寫你的第一個(gè)Django應(yīng)用,第5部分
視圖層
Django管理文檔生成器
編寫你的第一個(gè) Django 程序 第3部分
編寫你的第一個(gè)Django應(yīng)用,第6部分
模型層
中間件
測(cè)試
數(shù)據(jù)庫訪問優(yōu)化
文件上傳
中間件
驗(yàn)證器
基于類的內(nèi)建通用視圖
部署靜態(tài)文件
使用Django認(rèn)證系統(tǒng)
高級(jí)教程:如何編寫可重用的應(yīng)用
Model 類參考
Django 初探
使用Django輸出PDF
模型的實(shí)例
模型
文件上傳
進(jìn)行原始的sql查詢
面向程序員
中間件
編寫數(shù)據(jù)庫遷移
TemplateResponse 和 SimpleTemplateResponse
異常
Django中的測(cè)試
基礎(chǔ)
管理器
File對(duì)象
URL調(diào)度器
加密簽名
國際化和本地化
日志
查詢集
django-admin 和 manage.py
使用基于類的視圖處理表單
聚合
內(nèi)建基于類的視圖的API
如何使用會(huì)話
部署 Django
其它
其它核心功能
高級(jí)
Django中的密碼管理
模型元選項(xiàng)
按需內(nèi)容處理
查找 API 參考
高級(jí)
Django 的快捷函數(shù)
Django 的設(shè)置
Admin
開發(fā)過程
新手入門
基于類的視圖
模型實(shí)例參考
信號(hào)
表單素材 ( <code>Media</code> 類)
自定義查找
常見的網(wǎng)站應(yīng)用工具
模型
django.contrib.humanize
Django模版語言
點(diǎn)擊劫持保護(hù)
管理操作
編寫你的第一個(gè) Django 程序 第2部分
Django安全
模式編輯器
多數(shù)據(jù)庫
部署
基于類的視圖
內(nèi)建的視圖
視圖裝飾器
面向設(shè)計(jì)師
編寫視圖
應(yīng)用程序
如何使用WSGI 部署
參考
表單 API
文件儲(chǔ)存API
認(rèn)證
國際化和本地化
錯(cuò)誤報(bào)告
基礎(chǔ)
基礎(chǔ)
將遺留數(shù)據(jù)庫整合到Django
教程
Django異常
編寫你的第一個(gè) Django 程序 第4部分
遷移
分頁
重定向應(yīng)用
表單
從零開始
為模型提供初始數(shù)據(jù)
設(shè)置
使用Django輸出CSV
關(guān)聯(lián)對(duì)象參考
使用表單
Django 中的用戶認(rèn)證
快速安裝指南
安全問題歸檔
數(shù)據(jù)庫函數(shù)
編寫自定義的django-admin命令
高級(jí)教程
管理文件
格式本地化
基于類的通用視圖 —— 索引
安全
系統(tǒng)檢查框架
為Django編寫首個(gè)補(bǔ)丁
模板層
Widgets
編寫你的第一個(gè) Django 程序 第1部分
執(zhí)行查詢

文件儲(chǔ)存API

獲取當(dāng)前的儲(chǔ)存類

Django提供了兩個(gè)便捷的方法來獲取當(dāng)前的儲(chǔ)存類:

class DefaultStorage[source]

DefaultStorage 提供對(duì)當(dāng)前的默認(rèn)儲(chǔ)存系統(tǒng)的延遲訪問,像DEFAULT_FILE_STORAGE中定義的那樣。DefaultStorage 內(nèi)部使用了get_storage_class()。

get_storage_class([import_path=None])[source]

返回實(shí)現(xiàn)儲(chǔ)存API的類或者模塊。

當(dāng)沒有帶著import_path 參數(shù)調(diào)用的時(shí)候, get_storage_class 會(huì)返回當(dāng)前默認(rèn)的儲(chǔ)存系統(tǒng),像DEFAULT_FILE_STORAGE中定義的那樣。如果提供了import_pathget_storage_class會(huì)嘗試從提供的路徑導(dǎo)入類或者模塊,并且如果成功的話返回它。如果導(dǎo)入不成功會(huì)拋出異常。

FileSystemStorage類

class FileSystemStorage([location=None, base_url=None, file_permissions_mode=None, directory_permissions_mode=None])[source]

FileSystemStorage類在本地文件系統(tǒng)上實(shí)現(xiàn)了基本的文件存儲(chǔ)功能。它繼承自Storage ,并且提供父類的所有公共方法的實(shí)現(xiàn)。

location

儲(chǔ)存文件的目錄的絕對(duì)路徑。默認(rèn)為MEDIA_ROOT設(shè)置的值。

base_url

在當(dāng)前位置提供文件儲(chǔ)存的URL。默認(rèn)為MEDIA_URL設(shè)置的值。

file_permissions_mode

文件系統(tǒng)的許可,當(dāng)文件保存時(shí)會(huì)接收到它。默認(rèn)為FILE_UPLOAD_PERMISSIONS。

New in Django 1.7:

新增了file_permissions_mode屬性。之前,文件總是會(huì)接收到FILE_UPLOAD_PERMISSIONS許可。

directory_permissions_mode

文件系統(tǒng)的許可,當(dāng)目錄保存時(shí)會(huì)接收到它。默認(rèn)為FILE_UPLOAD_DIRECTORY_PERMISSIONS。

New in Django 1.7:

新增了directory_permissions_mode屬性。之前,目錄總是會(huì)接收到FILE_UPLOAD_DIRECTORY_PERMISSIONS許可。

注意

FileSystemStorage.delete()在提供的文件名稱不存在的時(shí)候并不會(huì)拋出任何異常。

Storage類

class Storage[source]

Storage類為文件的存儲(chǔ)提供了標(biāo)準(zhǔn)化的API,并帶有一系列默認(rèn)行為,所有其它的文件存儲(chǔ)系統(tǒng)可以按需繼承或者復(fù)寫它們。

注意

對(duì)于返回原生datetime對(duì)象的方法,所使用的有效時(shí)區(qū)為os.environ['TZ']的當(dāng)前值。要注意它總是可以通過Django的TIME_ZONE來設(shè)置。

accessed_time(name)[source]

返回包含文件的最后訪問時(shí)間的原生datetime對(duì)象。對(duì)于不能夠返回最后訪問時(shí)間的儲(chǔ)存系統(tǒng),會(huì)拋出NotImplementedError異常。

created_time(name)[source]

返回包含文件創(chuàng)建時(shí)間的原生datetime對(duì)象。對(duì)于不能夠返回創(chuàng)建時(shí)間的儲(chǔ)存系統(tǒng),會(huì)拋出NotImplementedError異常。

delete(name)[source]

刪除name引用的文件。如果目標(biāo)儲(chǔ)存系統(tǒng)不支持刪除操作,會(huì)拋出NotImplementedError異常。

exists(name)[source]

如果提供的名稱所引用的文件在文件系統(tǒng)中存在,則返回True,否則如果這個(gè)名稱可用于新文件,返回False。

get_available_name(name, max_length=None)[source]

返回基于name參數(shù)的文件名稱,它在目標(biāo)儲(chǔ)存系統(tǒng)中可用于寫入新的內(nèi)容。

如果提供了max_length,文件名稱長度不會(huì)超過它。如果不能找到可用的、唯一的文件名稱,會(huì)拋出SuspiciousFileOperation 異常。

如果name命名的文件已存在,一個(gè)下劃線加上隨機(jī)7個(gè)數(shù)字或字母的字符串會(huì)添加到文件名稱的末尾,擴(kuò)展名之前。

Changed in Django 1.7:

之前,下劃線和一位數(shù)字(比如"_1","_2",以及其他)會(huì)添加到文件名稱的末尾,直到目標(biāo)目錄中發(fā)現(xiàn)了可用的名稱。一些惡意的用戶會(huì)利用這一確定性的算法來進(jìn)行dos攻擊。這一變化也在1.6.6, 1.5.9, 和 1.4.14中出現(xiàn)。
Changed in Django 1.8:

新增了max_length參數(shù)。

get_valid_name(name)[source]

返回基于name參數(shù)的文件名稱,它適用于目標(biāo)儲(chǔ)存系統(tǒng)。

listdir(path)[source]

列出特定目錄的所有內(nèi)容,返回一個(gè)包含2元組的列表;第一個(gè)元素是目錄,第二個(gè)是文件。對(duì)于不能夠提供列表功能的儲(chǔ)存系統(tǒng),拋出NotImplementedError異常。

modified_time(name)[source]

返回包含最后修改時(shí)間的原生datetime對(duì)象。對(duì)于不能夠返回最后修改時(shí)間的儲(chǔ)存系統(tǒng),拋出NotImplementedError異常。

open(name, mode='rb')[source]

通過提供的name打開文件。注意雖然返回的文件確保為File對(duì)象,但可能實(shí)際上是它的子類。在遠(yuǎn)程文件儲(chǔ)存的情況下,這意味著讀寫操作會(huì)非常慢,所以警告一下。

path(name)[source]

本地文件系統(tǒng)的路徑,文件可以用Python標(biāo)準(zhǔn)的open()在里面打開。對(duì)于不能從本地文件系統(tǒng)訪問的儲(chǔ)存系統(tǒng),拋出NotImplementedError異常。

save(name, content, max_length=None)[source]

使用儲(chǔ)存系統(tǒng)來保存一個(gè)新文件,最好帶有特定的名稱。如果名稱為 name的文件已存在,儲(chǔ)存系統(tǒng)會(huì)按需修改文件名稱來獲取一個(gè)唯一的名稱。返回被儲(chǔ)存文件的實(shí)際名稱。

max_length參數(shù)會(huì)傳遞給get_available_name()。

content參數(shù)必須為django.core.files.File或者File子類的實(shí)例。

Changed in Django 1.8:

新增了max_length參數(shù)。

size(name)[source]

返回name所引用的文件的總大小,以字節(jié)為單位。對(duì)于不能夠返回文件大小的儲(chǔ)存系統(tǒng),拋出NotImplementedError異常。

url(name)[source]

返回URL,通過它可以訪問到name所引用的文件。對(duì)于不支持通過URL訪問的儲(chǔ)存系統(tǒng),拋出NotImplementedError異常。

譯者:Django 文檔協(xié)作翻譯小組,原文:Storage API。

本文以 CC BY-NC-SA 3.0 協(xié)議發(fā)布,轉(zhuǎn)載請(qǐng)保留作者署名和文章出處。

Django 文檔協(xié)作翻譯小組人手緊缺,有興趣的朋友可以加入我們,完全公益性質(zhì)。交流群:467338606。

上一篇:高級(jí)教程下一篇:面向程序員