| from easyocr import Reader |
| import cv2 |
| def cleanup_text(text): |
| |
| |
| return "".join([c if ord(c) < 128 else "" for c in text]).strip() |
|
|
| def arabic_ocr(image_path,out_image): |
| |
| langs = "ar,en".split(",") |
| gpu1=-1 |
| |
| |
| image = cv2.imread(image_path) |
| |
| print("[INFO] OCR'ing input image...") |
| reader = Reader(langs, gpu=-1 > 0) |
| results = reader.readtext(image) |
|
|
| |
| |
| filename=out_image |
| for (bbox, text, prob) in results: |
| |
| print("[INFO] {:.4f}: {}".format(prob, text)) |
| |
| (tl, tr, br, bl) = bbox |
| tl = (int(tl[0]), int(tl[1])) |
| tr = (int(tr[0]), int(tr[1])) |
| br = (int(br[0]), int(br[1])) |
| bl = (int(bl[0]), int(bl[1])) |
| |
| |
| text = cleanup_text(text) |
| cv2.rectangle(image, tl, br, (0, 255, 0), 2) |
| cv2.putText(image, text, (tl[0], tl[1] - 10), |
| cv2.FONT_HERSHEY_SIMPLEX, 0.8, (0, 255, 0), 2) |
| |
| cv2.imwrite(filename, image) |
| return results |
|
|