屬性列表
副檔名 |
.plist |
---|---|
網路媒體型式 | application/x-plist |
開發者 | 蘋果公司和GNUstep, 前NeXT |
格式類型 | 序列化對象 |
在OS X的Cocoa,NeXTSTEP和GNUstep編程框架中,屬性列表(Property List)檔案是一種用來儲存序列化後的對象的檔案。屬性列表檔案的副檔名為.plist,因此通常被稱為plist檔案。
Plist檔案通常用於儲存使用者設定,也可以用於儲存捆綁的資訊,該功能在舊式的Mac OS中是由資源分支提供的。
表達
由於Plist中儲存的資料是抽象的,其採用的檔案格式可以不止一種。NeXTSTEP只使用一種格式,而稍晚的GNUstep和OS X框架匯入了不同的檔案格式。
NeXTSTEP
NeXTSTEP系統中,Plist被設計為人類可讀的,並可以手工修改,故採用了類似於程式語言的語法將資料序列化為ASCII資料。
字串被表示為:
"This is a plist string"
二進制資料被表示為:
< [文本形式的十六进制数] >
陣列被表示為:
( "1", "2", "3" )
字典則被表示為:
{ "键" = "值"; ... }
NeXT的plist格式的一個限制是它不能表示NSValue對象(即數,布林值等)。
GNUstep
GNUstep採用了NeXTSTEP的格式,並添加了少許特性。它支援NSValue對象(以普通ASCII碼表示),支援NSDate(序列化成<*DYYYY-MM-DD HH:MM:SS timezone>的格式)。
GNUstep也可以讀寫OS X使用的Plist格式。
Mac OS X
Mac OS X在支援讀取NeXTSTEP格式的同時,並不鼓勵使用它,而是推薦使用Apple匯入的兩種新格式。
Mac OS X 10.0中,NeXTSTEP的格式被認為是不被推薦的,並匯入了一種新的XML格式,其由Apple定義的公開DTD所規格化。XML格式支援非ASCII格式,亦可儲存NSValue對象。但與GNUstep的ASCII plist格式不同,Apple的NeXTSTEP格式的plist檔案不支援這兩種特性。
由於XML檔案在儲存時不是最有空間效率的,Mac OS X 10.2匯入了一種新的格式,它將plist檔案儲存為二進制檔案。從Mac OS X 10.4開始,這是偏好設定檔案的預設格式。
plutil
工具(在Mac OS X 10.2中匯入)可以用來檢查plist的語法,或者對plist檔案進行格式轉換。
可以使用任何文字編輯器對XML格式的plist進行更改,同時,Apple提供了「Property List Editor」應用程式(作為Apple Developer Tools的一部分安裝),它是一個樹狀的檢視器與編輯器,並可以處理二進制格式的plist。
對於XML格式,XML標籤和相關Foundation類、Core Foundation類型、資料儲存格式的關係如下表所示:
Foundation類 | Core Foundation類型 | XML標籤 | 儲存格式 |
---|---|---|---|
NSString | CFString | <string> | UTF-8編碼的字串 |
NSNumber | CFNumber | <real>, <integer> | 十進制數字串 |
NSNumber | CFBoolean | <true />, or <false /> | 無資料(只有標籤) |
NSDate | CFDate | <date> | ISO 8601格式的日期字串 |
NSData | CFData | <data> | Base64編碼的資料 |
NSArray | CFArray | <array> | 可以包含任意數量的子元素 |
NSDictionary | CFDictionary | <dict> | 交替包含<key>標籤和plist元素標籤 |
defaults
工具可以用於以命令列形式,通過程式的偏好設定域,管理用於儲存偏好設定的plist檔案;而Property List Editor則可以用於編輯任何plist檔案(包括用於儲存偏好設定的)。從Mac OS X 10.4開始,Apple提供了通過System Events應用程式讀寫plist檔案的AppleScript介面,而從Mac OS X 10.5開始,Apple也提供了用於編輯,建立和寫入plist檔案的介面[1]。
參考文獻
參見
外部連結
- The plist manual page at developer.apple.com
- Property List Programming Guide for Cocoa
- Property List Programming Topics for Core Foundation
- NSPropertyListSerialization class documentation from the GNUstep project
- OpenStep plist API from Sun Microsystems
- Apache Commons Configuration Configuration API in Java supporting the Property List format
- Apple's Property List Document Type Definition
- BinaryPListParser.java from Quaqua project, which is listed as using a variant of the BSD licenses.
第三方編輯工具
- PlistEdit, a general property list editor
- PlistEdit Pro, a general property list editor
- PrefEdit, specializing in editing preference plists
- Property List Tools, an Applescript scripting addition for manipulating plists
- Pledit, a general property list editor for Microsoft Windows