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

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

ただいまの
回答率

88.06%

CoreDateで保存したデータを1つのセルに表示する方法

解決済

回答 1

投稿

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

score 62

前提・実現したいこと

SwiftのCoreDateを使ってToDoアプリを作成しようと考えています。
機能としてはカテゴリーを分けとToDoの日時を追加したいと考えています。

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

カテゴリー分けした際に、TableViewを使用し、ToDoと日時を同じCellに表示したいと考えているのですが上手くいきません。

該当のソースコード

以下がコードの全文になります

ViewController.swift

import UIKit
import CoreData

class AddTaskViewController: UIViewController {
    @IBOutlet weak var taskTextField: UITextField!
    @IBOutlet weak var categoryegmentedControl: UISegmentedControl!
    @IBOutlet weak var dateTextField: UITextField!

    var taskCategory = "ToDo"

    var datePicker: UIDatePicker = UIDatePicker()

    override func viewDidLoad() {
        super.viewDidLoad()

        // ピッカー設定
        datePicker.datePickerMode = UIDatePicker.Mode.date
        datePicker.timeZone = NSTimeZone.local
        datePicker.locale = Locale.current
        dateTextField.inputView = datePicker

        // 決定バーの生成
        let toolbar = UIToolbar(frame: CGRect(x: 0, y: 0, width: view.frame.size.width, height: 35))
        let spacelItem = UIBarButtonItem(barButtonSystemItem: .flexibleSpace, target: self, action: nil)
        let doneItem = UIBarButtonItem(barButtonSystemItem: .done, target: self, action: #selector(done))
        toolbar.setItems([spacelItem, doneItem], animated: true)

        // インプットビュー設定
        dateTextField.inputView = datePicker
        dateTextField.inputAccessoryView = toolbar
    }

    @IBAction func categoryChosen(_ sender: UISegmentedControl) {
        switch sender.selectedSegmentIndex {
        case 0:
            taskCategory = "Indivisual"
        case 1:
            taskCategory = "Job"
        case 2:
            taskCategory = "Shopping"
        case 3:
            taskCategory = "Other"
        default:
            taskCategory = "ToDo"
        }
    }

    @IBAction func cancelButtonTapped(_ sender: Any) {
        dismiss(animated: true, completion: nil)
    }

    @IBAction func plusButtonTapped(_ sender: Any) {
        // TextFieldに何も入力されていない場合は何もせずに1つ目のビューへ戻る
        let taskName = taskTextField.text
        let taskDate = dateTextField.text

        if taskName == "" {
            dismiss(animated: true, completion: nil)
            return
        }

        // contextを定義
        let context = (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext

        // taskにTask型オブジェクトを代入
        let task = Task(context: context)

        //選択したデータを代入
        task.name = taskName
        task.category = taskCategory
        task.date = taskDate

        // データベースに保存
        (UIApplication.shared.delegate as! AppDelegate).saveContext()

        dismiss(animated: true, completion: nil)
    }

    @objc func done() {
        dateTextField.endEditing(true)

        // 日付のフォーマット
        let formatter = DateFormatter()
        formatter.dateFormat = "yyyy-MM-dd"
        dateTextField.text = "\(formatter.string(from: Date()))"
    }
}

ViewController.swift

import UIKit
import CoreData

class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate {
    @IBOutlet weak var taskTableView: UITableView!

    // MARK: - Properties for table view

    var tasks:[Task] = []
    var tasksToShow:[String:[String]] = ["Indivisual":[], "Job":[], "Shopping":[], "Other":[]]
    let taskCategories:[String] = ["Indivisual", "Job", "Shopping", "Other"]

    // MARK: - Table View Data Source

    // taskCategories[]に格納されている文字列がTableViewのセクションになる
    func numberOfSections(in tableView: UITableView) -> Int {
        return taskCategories.count
    }

    func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
        return taskCategories[section]
    }

    // tasksToShowにカテゴリー(tasksToShowのキーとなっている)ごとのnameが格納されている
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return tasksToShow[taskCategories[section]]!.count
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = UITableViewCell()

        let sectionData = tasksToShow[taskCategories[indexPath.section]]
        let cellData = sectionData?[indexPath.row]

        cell.textLabel?.text = "\(cellData!)"

        return cell
    }

    // MARK: - View Life Cycle

    override func viewDidLoad() {
        super.viewDidLoad()

        taskTableView.dataSource = self
        taskTableView.delegate = self
    }

    override func viewWillAppear(_ animated: Bool) {
        // CoreDataからデータをfetchしてくる
        getData()

        // taskTableViewを再読み込みする
        taskTableView.reloadData()
    }

    // MARK: - Method of Getting data from Core Data

    func getData() {
        // データ保存時と同様にcontextを定義
        let context = (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext
        do {
            // CoreDataからデータをfetchしてtasksに格納
            let fetchRequest: NSFetchRequest<Task> = Task.fetchRequest()
            tasks = try context.fetch(fetchRequest)

            // tasksToShow配列を空にする。(同じデータを複数表示しないため)
            for key in tasksToShow.keys {
                tasksToShow[key] = []
            }
            // 先ほどfetchしたデータをtasksToShow配列に格納する
            for task in tasks {
                tasksToShow[task.category!]?.append(task.name!)
                tasksToShow[task.category!]?.append(task.date!)
            }
        } catch {
            print("Fetching Failed.")
        }
    }
}

試したこと

tasksToShow[task.category!]?.append(task.name!)
tasksToShow[task.category!]?.append(task.date!)


このコードがtask.categoryに関連したtask.nametask.dateを表示していると思ったので、
イメージ説明

tasksToShow[task.category!]?.append(task.name!)
tasksToShow[task.name!]?.append(task.date!)


task.categoryに関連したtask.nameを表示し、
そのtask.nameに関連したtask.dateを表示するような形にすれば1つのCellに表示されると考えたのですが表示されなくなりました
イメージ説明

1つのセルに表示するためにアドバイスいただけたら幸いです。
よろしくお願いいたします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • MasakiHori

    2019/03/05 18:43

    「UITableViewCell カスタムセル」あたりでググればいいんじゃないかなぁ

    キャンセル

回答 1

checkベストアンサー

+1

結論として、かなりベーシックな問題です。UITableViewController関連のチュートリアルをゼロからやってみてください。

解決方法は複数ですね。

正しいのはカスタムセルで

cell.nameLabel.text = name
cell.dateLabel.text = date

ディフォルトの「textLabel」をつかうなら:

cell.textLabel?.text = "\(name!) \(date!)"

こいう言うデモをみてみてください。swift 3.1なのに、出発点としていいです。
https://github.com/deege/deegeu-ios-swift-tableview-custom-cells

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

  • ただいまの回答率 88.06%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

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