9
File size: 2,176 Bytes
a8c7844
 
 
 
 
 
e18064f
a8c7844
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
53d49cb
814d1f2
53d49cb
76fe2ed
9df55ee
0a4bebb
de68c9b
53d49cb
a8c7844
e18064f
94173d8
6abc6c8
53d49cb
6abc6c8
a8c7844
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
import gradio as gr
from azure.ai.vision.imageanalysis import ImageAnalysisClient
from azure.ai.vision.imageanalysis.models import VisualFeatures
from azure.core.credentials import AzureKeyCredential


def ocr_image_file(image1, end_point, API_Key):
    
    if (end_point == '' or API_Key == ''):
        output = "*** Please provide EndPoint URL and API_KEY ***"
    else:
        try:
            endpoint = end_point
            key = API_Key
            # Create an Image Analysis client
            client = ImageAnalysisClient(
                endpoint=endpoint,
                credential=AzureKeyCredential(key)
            )
            # [START read]
            # Load image to analyze into a 'bytes' object
            with open(image1, "rb") as f:
                image_data = f.read()

            # Extract text (OCR) from an image stream. This will be a synchronously (blocking) call.
            result = client.analyze(
                image_data=image_data,
                visual_features=[VisualFeatures.READ]
            )
            if result.read is not None:
                sentence = ''
                for line in result.read.blocks[0].lines:
                    sentence += f"    {line.text}" + "\n"  
                    print(f"   Line: '{line.text}'")
                    output = sentence
            
        except :
            output = "*** Please check EndPoint URL and API_KEY ***"

    return output

title = "Azure Cognitive Services"
description = """ 
 <img src = "https://nightingalehq.ai/knowledgebase/glossary/what-are-azure-cognitive-services/cognitive-services.jpg" width = 300px>

# Computer Vision : OCR or Optical Character Recognition for text recognition or text extraction.
 
"""
    
demo = gr.Interface( ocr_image_file,
                    [gr.UploadButton("Click to Upload an Image File", file_types=["image"]), gr.Textbox(label="Enter your Endpoint URL", placeholder="URL", lines=1),gr.Textbox(type = "password", label="Enter your API-Key", placeholder="API-Key", lines=1)],
                    [gr.Textbox(label = "Output")],
                    title=title,
                    description=description,

).launch()