18
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

LINE botとMakeでOCRに挑戦!LINEで食品表示の画像をテキストに変換しよう

Last updated at Posted at 2022-05-29

初めて使うツールでいろいろやってみよう!

はじめまして、こんにちは。
私は全然ITとは関係ない会社で働く会社員です。
(食品検査の仕事をしています。)

仕事では紙にまみれた生活をしており、デジタルとかよくわかりません。
今回、ノーコードでLINEbotを作成できるツールを知る機会があり、
せっかくなのでいろいろ試してみたいと思い、筆をとりました。

仕事では紙に印刷された文字をデータ入力するという機会も多く、OCRに興味があります。
食品検査の仕事なので、依頼品の食品のパッケージから表示部分の情報を読んで、
社内の受付システムに入力するという作業は毎日発生しています。
(食品表示というのは原材料や内容量、アレルゲン情報や賞味期限などが記載された部分のことです。)
そこで、表示部分をLINEで撮影して、その画像をOCRしてテキストとして見れたら
検索したりコピペするときに便利なんじゃないのと思い、挑戦しました。

なお、参考にした資料を初心者がわからないなりに真似したため、
Google Apps Scriptを使うなど、完全ノーコードではできませんでした。

使用したツール

  • LINE Developer
  • MAKE(旧integromat)
  • Googleドライブ
  • Googleスプレッドシート
  • Google Apps Script(GAS)

作りたかった流れ

LINEで写真を撮影し、画像をbotへ送る → 画像をgoogleドライブに保存 → googleドライブでGASを動かしてOCRで文字列を得る
→ 文字列をGoogleスプレッドシートに記入 → Googleスプレッドシートの文字列を読んでLINEに返す

完成品

Screenshot_20220529-184112提出.png

Makeのシナリオ画面

シナリオ提出.png

動画

参考にした資料

Google Apps Script

OCRの処理の部分は参考にした資料からまるごとコピーさせていただきました。

ソースコードを表示(折りたたみ)
OCR.gs

//OCRの処理の部分
const folderId = "画像が入るフォルダID"
function myFunction() {
  // フォルダーに入っているファイル一覧を取得
  let a = Drive.Children.list(folderId)
  
  // 設定事項を書いていく
  let resource = {
    title: "test" // ここは途中で生成されるファイル名の指定です(ファイルを消すのでなんでもいいです)
  };
  let option = {
    "ocr": true,// OCRを行うかの設定です
    "ocrLanguage": "ja",// OCRを行う言語の設定です
  }
  
  // 取得したファイル一覧の最初のもののfileIdを変数に格納します
  let fileId = a.items[0].id
  // 指定したfileIdのファイルをコピーします
  let image = Drive.Files.copy(resource, fileId, option)
  // コピー先ファイルにはOCRのデータが含まれているのでテキストを取得します
  let text = DocumentApp.openById(image.id).getBody().getText();
  // コピー先ファイルはもう不要なので削除
  Drive.Files.remove(image.id)
  // OCRした内容を表示
  console.log(text)

//OCRの処理おわり

//ここから書き足した部分
//OCRで取得したtextをスプレッドシートに書き込む処理
  var id = "結果を書き込むスプレッドシートのID"
  var ss = SpreadsheetApp.openById(id)
  var sheet = ss.getActiveSheet()
  sheet.getRange("A1").setValue(text)

//OCR済みの画像ファイルを別のフォルダに移す処理
 var file = DriveApp.getFileById(fileId);
  
  //移動先のフォルダを取得
  var folder = DriveApp.getFolderById("移動先の別のフォルダID");
  
  //ファイルを移動
  file.moveTo(folder);

} 

反省点

今回、なんとか動くものが作れましたが、後半かなり力技でねじ伏せているのでもっと時間をかけて調べたいです。
もっと時間があれば、LINEに画像以外のものが投稿された場合の分岐なども設定できそうでしたが、
残念ながらここまで。

(無理やりつなげたところ)
参考資料のスクリプトをそのままコピーしてGASのファイルを作ったものの、
OCRで得られた文字列をどうやって取り出すのかわかりませんでした。
そこで、GASのスクリプトに直接コードを書き込んで、GoogleスプレッドシートのA1にOCRのテキストを入れる処理をしています。
また、書き込んだ後の画像は別のフォルダに移す処理も書き込んでいます。
(私はExcelのVBAだけわかるのでGASも調べたらなんとかなりそうな雰囲気でした。)

さらにGASの起動方法もよくわからなかったので、GAS起動のトリガーを1分ごとに設定し、
OCRで読み込まれた画像が入るフォルダに対して1分ごとにこのGASが実行されています。

以上のことから、画像がフォルダに入ったタイミングでOCR用のGASが動かないため、
MakeのToolsで30秒待機しています。
なので、非常にもっさりした動きではありますが、一応動いたので目標は達成できたと思いたいです。

今後の展望

Makeは非常に便利なツールで、使いこなせたら便利なものが簡単に作れそうです。
しかし、日本語の情報が少ないのがなかなか辛かったです。
(Google翻訳で戦いましたが、私には厳しかったです。)
GASとかのほうが情報が多いので、うまくノーコードツールと組み合わせて、
自分のやりたいことを達成すれば初心者でもなんとかいけそうな気がしました。

以上、御覧いただきましてありがとうございました。

18
8
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
18
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?