Android StudioでOCRでレシートを読み取るアプリを作っています。
Google Cloud Visionでレシートを読み取り、日付部分を正規表現で抽出したあとreplaceメソッドでフォーマットを正してRealmにデータを入れ、それを画面上に表示させたいと思いました。
コードの一部です。
java
1//日付取得の処理 2//strはレシートの文字列全体です 3 regaxdate = "\d{4}-\d{1,2}-\d{1,2}|\d{4}/\d{1,2}/\d{1,2}|\d{4}年\d{1,2}月\d{1,2}日"; 4 Pattern pdate = Pattern.compile(regaxdate); 5 Matcher mdate = pdate.matcher(str); 6 if (mdate.find()) { 7 matchdate = mdate.group(); 8 } 9 matchdate.replace("年", "/"); 10 matchdate.replace("月", "/"); 11 matchdate.replace("日", "/"); 12
kotlin
1open class ResitoDetail : RealmObject() { 2 @PrimaryKey 3 var detailId: Long = 1L 4 var kei: Int? = null 5 var hiduke: String? =null 6}
kotlin
1 val resitodate = findViewById<TextView>(R.id.resito_date) 2 val resitokei = findViewById<EditText>(R.id.resito_kei) 3 4 realm.executeTransaction{ 5 val maxdetailId = realm.where<ResitoDetail>().max("detailId") 6 val targetdetailId = (maxdetailId?.toLong() ?: 0L) + 1L 7 val detail = realm.createObject<ResitoDetail>(targetdetailId) 8 detail.hiduke = ResitoActivity.matchdate 9 detail.kei = ResitoActivity.kei 10 } 11 var str1: String 12 var str2: String 13 str1 = realm.where(ResitoDetail::class.java).equalTo("hiduke",0.toInt()).toString() 14 str2 = realm.where(ResitoDetail::class.java).equalTo("kei", 0.toInt()).toString() 15 16 17 resitodate.setText(str1) 18 resitokei.setText(str2)
タイトルのエラー文を調べると変数を変えるとこのエラーが出ると書いてあり、変数の再定義、変数名の変更、アプリのアンインストール、Realmクラスの再定義を行いましたが変わらずでした。
どうすればいいかわからなくなりました。
どなたかご教授お願いします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/02/06 04:34
2019/02/06 04:50