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

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

ただいまの
回答率

89.19%

Cannot convert value of type '〇〇.Type' expected argument type 'Object.Type'エラーとは何ですか?

解決済

回答 1

投稿

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

iOS25535009

score 4

前提・実現したいこと

Swiftでタスク管理アプリを作っています。下記のエラーが発生していますが、なぜでしょうか?

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

Cannot convert value of type 'Category.Type' (aka 'OpaquePointer.Type') to expected argument type 'Object.Type'
Cannot invoke initializer for type 'Category' with no arguments

該当のソースコード

https://gyazo.com/b3efdda5e2221fccbe81141e1ac1e18b

import UIKit
import RealmSwift
import UserNotifications

class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource,UISearchBarDelegate,UIPickerViewDelegate, UIPickerViewDataSource {


    @IBOutlet weak var searchBarField: UISearchBar!
    @IBOutlet weak var tableView: UITableView!

    @IBOutlet weak var searchPickerView: UIPickerView!

    // Realmインスタンスを取得する
    let realm = try! Realm() 
    //print(path)
    // DB内のタスクが格納されるリスト。
    // 日付近い順\順でソート:降順
    // 以降内容をアップデートするとリスト内は自動的に更新される。
    var taskArray = try! Realm().objects(Task.self).sorted(byKeyPath: "date", ascending: false)

    var dataList = try! Realm().objects(Category.self)
    var drumRollRow:Int!

    override func viewDidLoad() {
        super.viewDidLoad()
        dump(taskArray)
        print("fff")
        searchBarField?.delegate = self
        // Do any additional setup after loading the view, typically from a nib.
        tableView.delegate = self
        tableView.dataSource = self
        searchPickerView.delegate = self
        searchPickerView.dataSource = self
        self.tableView.reloadData()
        let category = Category()
        let allCategory = realm.objects(Category.self)
        if allCategory.count == 0 {

            //category.id = 1
            category.category_title = "全て"
            try! realm.write {
                self.realm.add(category, update: true)
            }
            //realm.add(category, update: true)
        }
        self.searchPickerView.reloadAllComponents()

    }
    func numberOfComponents(in pickerView: UIPickerView) -> Int {
        return 1
    }
    func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
        drumRollRow = row
        if(row != 0) {
            taskArray = try! Realm().objects(Task.self).filter("category.id = \(row)")
        } else {
            taskArray = try! Realm().objects(Task.self)
        }

        self.tableView.reloadData()

    }
    func pickerView(_ pickerView: UIPickerView,
                    numberOfRowsInComponent component: Int) -> Int {
        return dataList.count
    }
    func pickerView(_ pickerView: UIPickerView,
                    titleForRow row: Int,
                    forComponent component: Int) -> String? {

        return dataList[row].category_title
    }

    // MARK: UITableViewDataSourceプロトコルのメソッド
    // データの数(=セルの数)を返すメソッド
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

        //self.tableView.reloadData()
        return taskArray.count
    }

    // 各セルの内容を返すメソッド
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

        // 再利用可能な cell を得る
        let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath)

        // Cellに値を設定する. 
        let task = taskArray[indexPath.row]
        //dump(indexPath.row)
        cell.textLabel?.text = task.title

        let formatter = DateFormatter()
        formatter.dateFormat = "yyyy-MM-dd HH:mm"

        let dateString:String = formatter.string(from: task.date)
        cell.detailTextLabel?.text = dateString


        return cell
    }

    func searchBarCancelButtonClicked(_ searchBar: UISearchBar) {

        taskArray = try! Realm().objects(Task.self).sorted(byKeyPath: "date", ascending: false)
        self.tableView.reloadData()
    }

    // MARK: UITableViewDelegateプロトコルのメソッド
    // 各セルを選択した時に実行されるメソッド
    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        performSegue(withIdentifier: "cellSegue",sender: nil)
    }

    // セルが削除が可能なことを伝えるメソッド
    func tableView(_ tableView: UITableView, editingStyleForRowAt indexPath: IndexPath)-> UITableViewCell.EditingStyle {
        return .delete
    }

    // Delete ボタンが押された時に呼ばれるメソッド
    func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCell.EditingStyle, forRowAt indexPath: IndexPath) {

        if editingStyle == .delete {
            // 削除するタスクを取得する
            let task = self.taskArray[indexPath.row]

            // ローカル通知をキャンセルする
            let center = UNUserNotificationCenter.current()
            center.removePendingNotificationRequests(withIdentifiers: [String(task.id)])

            // データベースから削除する
            try! realm.write {
                self.realm.delete(task)
                tableView.deleteRows(at: [indexPath], with: .fade)
            }

            // 未通知のローカル通知一覧をログ出力
            center.getPendingNotificationRequests { (requests: [UNNotificationRequest]) in
                for request in requests {
                    //print("/---------------")
                    print(request)
                    //print("---------------/")
                }
            }
        } 
    }



    // segue で画面遷移するに呼ばれる
    override func prepare(for segue: UIStoryboardSegue, sender: Any?){
        let inputViewController:InputViewController = segue.destination as! InputViewController

        if segue.identifier == "cellSegue" {
            let indexPath = self.tableView.indexPathForSelectedRow
            inputViewController.task = taskArray[indexPath!.row]
            inputViewController.touchrow = 1
        } else {
            // 新規
            let task = Task()
            task.date = Date()
            let allTasks = realm.objects(Task.self)
            if allTasks.count != 0 {
                task.id = allTasks.max(ofProperty: "id")! + 1
            }

            inputViewController.task = task
            inputViewController.touchrow = 2
        }
    }

    // 入力画面から戻ってきた時に TableView を更新させる
    override func viewWillAppear(_ animated: Bool) {
        super.viewWillAppear(animated)
        tableView.reloadData()
        searchPickerView.reloadAllComponents()
    }


}


この「Category」の部分でエラーが発生している

   var dataList = try! Realm().objects(Category.self)
    var drumRollRow:Int!

    override func viewDidLoad() {
        super.viewDidLoad()
        dump(taskArray)
        print("fff")
        searchBarField?.delegate = self
        // Do any additional setup after loading the view, typically from a nib.
        tableView.delegate = self
        tableView.dataSource = self
        searchPickerView.delegate = self
        searchPickerView.dataSource = self
        self.tableView.reloadData()
        let category = Category()
        let allCategory = realm.objects(Category.self)
        if allCategory.count == 0 {

試したこと

google翻訳で「タイプ「Category.Type」(別名「OpaquePointer.Type」)の値を期待される引数タイプ「Object.Type」に変換できません」「引数なしで 'Category'型の初期化子を呼び出すことはできません」とありましたが、意味がわかりません。検索をかけてもこれに該当するものはありませんでした。

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

Xcode 10.3
Swift 5.0.1

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • scorebook.dig

    2019/08/12 10:05

    Categoryクラスの定義を追記してください。

    キャンセル

  • iOS25535009

    2019/08/12 16:50

    ありがとうございました

    キャンセル

回答 1

check解決した方法

0

Raelmのモデルクラス(左のフォルダを右クリック→New File...でCategory.swift)を作り、

import RealmSwift

class Category: Object {
}


でクラス定義したら、消えました。
(Realmのモデルクラスとして定義するCategoty型がObject型を継承する形で定義)

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

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