質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.51%

  • Swift

    8741questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Xcode

    4916questions

    Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

  • Realm

    258questions

    RealmとはSQLiteやCore Dataに代わるモバイルデータベースです。iOSとAndroidの両方でサポートされています。

  • ArrayList

    104questions

    Java用のタグです。arrayListはListインターフェースを実装した、リサイズ可能な配列用クラスです。

RealmSwiftのListがソートできない。

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 295

kizahashi

score 4

 前提・実現したいこと

Swift4でRealmを使ったタスクアプリを作成しているのですが
RealmのList<>の型でソートをすることができません

textFieldに入力したタスクとその入力時刻をfunc textFieldShouldReturnのところでTaskList.listに追加しています。

そしてcellForRowAt内で

sortedTaskResult = realm.objects(Task.self).sorted(byKeyPath: "date", ascending: false)


という感じにしてタスクを入力時刻順でソートしようとを試みているのですが
sortedTaskResultを出力してみると中身は空になってしまっています。

どうすればTaskList.listをソートできるのでしょうか
そもそもRealmでArrayを保存しソートできるような状態でTableViewに表示したい場合はどうするのがスタンダードなのでしょうか?

数日間苦戦していてとても困っております
御回答よろしくお願いいたします。

 発生している問題・エラーメッセージ

'RLMException', reason: 'Index 0 is out of bounds (must be less than 0).'

 該当のソースコード

import Foundation
import RealmSwift

class Task: Object{
    @objc dynamic var name: String!
    @objc dynamic var date = "2018/10/18 12:00"
}
class TaskList: Object {
    let list = List<Task>()
    @objc dynamic var name: String!
    @objc dynamic var date = "2018/10/18 12:00"
}
import UIKit
import RealmSwift

class ViewController: UIViewController,UITableViewDelegate,UITableViewDataSource,UITextViewDelegate,UITextFieldDelegate,TestDelegate{

    var numberOfcells = 0
    var cellNumberArray:[Int] = []

    private var realm: Realm!
    private var sortedTaskResult: Results<Task>!

    let taskList = TaskList()


    @IBOutlet weak var vcTextField: UITextField!
    @IBOutlet weak var myTableView: UITableView!
    @IBOutlet weak var label1: UILabel!

    override func viewDidLoad() {
        super.viewDidLoad()

        realm = try! Realm() 
  }



    func textFieldShouldReturn(_ textField: UITextField) -> Bool{
        vcTextField.resignFirstResponder()

        let inputText = vcTextField.text

        numberOfcells += 1
        cellNumberArray.insert(numberOfcells, at: cellNumberArray.startIndex)

        let now = NSDate()
        let formatter = DateFormatter()
        formatter.dateFormat = "yyyy/MM/dd H:mm:ss"
        let string = formatter.string(from: now as Date)

        let task = Task()

        task.name = "\(inputText!)"//入力したタスクを追加
        task.date = "\(string)"//入力時刻を追加

        taskList.list.append(task)
        if cellNumberArray.count == 0{
            taskList.list.append(task)} //なぜかTasklist.listの中が1つだと表示されないので初回だけ二回


        vcTextField.text = ""

               myTableView.reloadData()
                return true
            }


    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

        return cellNumberArray.count
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! TableViewCell

        sortedTaskResult = realm.objects(Task.self).sorted(byKeyPath: "date", ascending: false)


        cell.textLabel?.text = "\(cellNumberArray[indexPath.row])"
        cell.taskLabel.text = taskList.list[indexPath.row].name
        cell.dateLabel.text = taskList.list[indexPath.row].date

        return cell
    }

    func deleteTodoItem2() {
        try! realm.write {
            realm.deleteAll()

        }
    }

    @IBAction func dataSent(_ sender: Any) {

        label1.text = "レルムデータ全削除"

        deleteTodoItem2()
    }
}

 補足情報(FW/ツールのバージョンなど)

Swift4.1

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • fuzzball

    2018/10/19 09:15

    cellArrayというのは何でしょうか?エラーはどこで出ているのでしょうか?なぜtableView(_:cellForRowAt:)の中でソートしているのでしょうか?sortedTaskResultを使っているところが無いのですが?

    キャンセル

  • kizahashi

    2018/10/19 13:40

    すみません不完全でした tableView(_:cellForRowAt:)以外でもソートできるのですね。

    キャンセル

回答 1

check解決した方法

0

タスクアプリを作るのであればList<>は必ずしも必要というわけではありませんでした

class taskAndDateData: Object {
    @objc dynamic var date = ""
    @objc dynamic var task = ""
}
func saveData(task1: String,date1: String){

        let data = taskAndDateData()
        data.task = task1
        data.date = date1
        try! self.realm.write {
            self.realm.add(data)
        }


このように普通に書き込んだだけでもデータが追加されるので
あとは

  let data = self.realm.objects(taskAndDateData.self).sorted(byKeyPath: "date", ascending: false)


でソートしたものを[indexpath.row].dateで表示しました

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

同じタグがついた質問を見る

  • Swift

    8741questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Xcode

    4916questions

    Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

  • Realm

    258questions

    RealmとはSQLiteやCore Dataに代わるモバイルデータベースです。iOSとAndroidの両方でサポートされています。

  • ArrayList

    104questions

    Java用のタグです。arrayListはListインターフェースを実装した、リサイズ可能な配列用クラスです。