[Swift] プロパティリスト(plist)を使ってCoreDataで一括登録する
公開日:
:
最終更新日:2014/12/09
iPhone App 開発, Swift
Warning: Use of undefined constant user_level - assumed 'user_level' (this will throw an Error in a future version of PHP) in /home/users/1/juny/web/hidef/wp-content/plugins/ultimate-google-analytics/ultimate_ga.php on line 524
プロパティリストを使う
初期データやあらかじめ用意したデータを一括登録したい場合、プロパティリストを使うと便利です。
プロジェクトの設定などは、info.plistとしておなじみですね。
構造としてはxml形式でKey、Type、Valueとして登録が可能です。
入力する際に各項目をCoreDataと適合させて登録します。
- plistのファイル名 = CoreDataのエンティティ名
- Key = エンティティのAttribute
- Type = エンティティのType
- Value = エンティティのデータ値
今回は以前の記事を雛形に、SampleEntityテーブルにflg項目を追加しました。

このエンティティにこれから用意するplistから一括登録してみたいと思います。
SampleEntity.plist(プロパティリストの新規作成)
名前はSampleEntity.plist、これに以下のようにデータを入力します。

RootをArrayにして、各項目をDictionaryに追加していきます。
KeyとTypeをエンティティに合わせること。
例では計3データになります。
SampleEntity.swift
そしてSampleEntityのNSManagedObjectは以下のように修正してください。
import Foundation
import CoreData
@objc(SampleEntity)
class SampleEntity: NSManagedObject {
@NSManaged var id: NSNumber?
@NSManaged var name: String?
@NSManaged var flg: NSNumber?
}
@objc(SampleEntity)を書いておかないと警告が出てしまうので追加。
AppDelegate.swift
AppDelegate.swiftに以下の関数を追加してください。
func insertDataFromPlist(entityName: String, managedObjectContext: NSManagedObjectContext) -> NSError? {
NSFetchedResultsController.deleteCacheWithName(nil)
let managedObjectModel = managedObjectContext.persistentStoreCoordinator?.managedObjectModel
let attrs = managedObjectModel?.entitiesByName[entityName]?.attributesByName
let path = NSBundle.mainBundle().pathForResource(entityName, ofType: "plist")
var keyedValues = NSArray(contentsOfFile: path!)!
for keyedValueDict in keyedValues {
let managedObject: AnyObject = NSEntityDescription.insertNewObjectForEntityForName(entityName,
inManagedObjectContext:managedObjectContext)
if let attributeArray = attrs as? [String: NSAttributeDescription] {
for attributeKey in attributeArray.keys {
let value: AnyObject? = keyedValueDict.objectForKey(attributeKey)
if value == nil {
continue
}
let attributeType = attributeArray[attributeKey]?.attributeType
if attributeType == NSAttributeType.StringAttributeType && value is NSNumber {
let value = value?.stringValue
} else if ((attributeType == NSAttributeType.Integer16AttributeType)
|| (attributeType == NSAttributeType.Integer32AttributeType)
|| (attributeType == NSAttributeType.Integer64AttributeType)
|| (attributeType == NSAttributeType.BooleanAttributeType)) && value is NSString
{
let value = value as NSNumber
}
else if attributeType == NSAttributeType.FloatAttributeType && value is NSString
{
let value = value as NSNumber
}
managedObject.setValue(value, forKey: attributeKey)
}
}
}
var error: NSError? = nil
managedObjectContext.save(&error)
return error?
}
まずNSFetchedResultsControllerのキャッシュをクリア。
managedObjectModelからエンティティの属性を取得し、plistから取得した値をタイプによって格納していきます。
8行目のfor文でplistのデータ数分繰り返します。
12行目のfor文で属性ごとにTypeを判断してNSManagedObjectに格納します。
36行目でデータを保存。
今回は起動時に登録するのでAppDelegateのdidFinishLaunchingWithOptionsに上記の関数を呼び出します。
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
let navigationController = self.window!.rootViewController as UINavigationController
let controller = navigationController.topViewController as MasterViewController
controller.managedObjectContext = self.managedObjectContext
self.insertDataFromPlist("SampleEntity", managedObjectContext: self.managedObjectContext!)
return true
}
MasterViewController.swift
データ表示のconfigureCellを以下のように修正。
func configureCell(cell: UITableViewCell, atIndexPath indexPath: NSIndexPath) {
let object = self.fetchedResultsController.objectAtIndexPath(indexPath) as SampleEntity
cell.textLabel?.text = "\(object.name!) (id:\(object.id!) flg:\(object.flg!))"
}
結果
まとめ
データ量が少なければUserDefaultsを使うのも一つの考えですが、今回のようにデータ量が肥大する可能性がある場合はプロパティリストを使ったほうが便利だと思います。
ad
関連記事
-
-
[Swift] CoreDataで検索したデータを削除する
CoreDataの検索と削除 前の投稿 CoreDataを使ってみる をふまえて今度は検索&削除
-
-
[Objective-C] iPhoneアプリからのメーラー起動
今回はiPhoneアプリからメーラーを起動する処理を紹介します。 メーラー起動のコントローラー
-
-
[Swift] optional値の設定(??)
optional値がnilの時 プロジェクトでのテンプレートを選択した時にソースコードが自動生成さ
-
-
[Swift] 画像を合成する
画像を合成 以下の2つの画像を合成してみます。円と四角です。 画像をプロジェクトに追
-
-
[Swift] ビルド時のエラー&iOS8でNSBigDecimalのバグ
ビルド時のエラー Swiftプロジェクトを実行中に以下のエラーが出ました。 "__TFSs15_
-
-
小さなことからコツコツと
これまでHTMLとCSSだけで生きてきただけあって、プログラム言語がいまいちわからない。 Mo
-
-
[Swift] UITabBarControllerでタブ選択時のイベントを取得する
UITabBarController タブを使った画面を作成する場合はUITabBarContro
-
-
[Objective-C] 小数点を丸める!(数値変換)
小数点を含む数値 Objective-Cに限らず、小数点を含む数値を計算する場合はdoubleやf
-
-
[Objective-C] UINavigationControllerのセグエを使って画面遷移をする
画面遷移の実装 今回はUINavigationControllerを使って画面遷移をしたいと思いま
