상위 목록: 하위 목록: 작성 날짜: 읽는 데 6 분 소요

Tesseract Korea OCR

Tesseract - OCR를 이용하여 Bitmap으로된 이미지 파일에서 한글을 인식하여 string형식으로 반환하여 인식합니다.



Tesseract 준비

1강에서 설치한 Tesseract 언어 데이터 파일프로젝트/bin/Debug에 저장합니다.


tessdata 폴더에 위와 같은 kor.traineddata 파일이 정상적으로 저장되어있는지 확인합니다.



프로젝트 구성

Form창에 위와 같이 pictureBoxbutton을 배치합니다.

pictureBox에 이미지를 등록합니다.



전체 코드

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using Tesseract;

namespace tesseract
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            Bitmap img = new Bitmap(pictureBox1.Image);
            var ocr = new TesseractEngine("./tessdata", "kor", EngineMode.Default);
            var texts = ocr.Process(img);
            MessageBox.Show(texts.GetText());
        }
    }
}


세부 코드

using Tesseract;

namespaceTesseract를 사용할 수 있도록 선언합니다.


Bitmap img = new Bitmap(pictureBox1.Image);

pictureBox1의 이미지를 Bitmap으로 변환하여 img 변수에 저장합니다.


var ocr = new TesseractEngine("./tessdata", "kor", EngineMode.Default);

ocr 변수에 TesseractEngine()을 이용하여 언어 데이터 파일을 사용하여 판독합니다.

TesseractEngine(언어 데이터 파일 경로, 언어, 엔진모드)입니다. 한글의 경우 kor입니다.

  • Tip : 한글은 EngineMode.Default만 지원합니다.


var texts = ocr.Process(img);
MessageBox.Show(texts.GetText());

textsocr에서 셋팅된 방법으로 img를 이용해 판독할 문자들을 저장합니다.

texts.GetText()를 이용하여 string형태로 불러올 수 있습니다.



출력 결과

댓글 남기기