-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.py
92 lines (72 loc) · 2.48 KB
/
main.py
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
import os, io, requests, uuid, time, json
from pdf2image import convert_from_bytes
from starlette.datastructures import Headers
from fastapi import FastAPI, UploadFile, File, Form
from dotenv import load_dotenv
from rag import get_rag_response
load_dotenv()
app = FastAPI(
title="Safe Zip",
description="Safe Zip BE",
)
@app.post("/ocr")
def get(image_file: UploadFile = File(...), is_landlord: str = Form("0"), user_question: str = Form("")):
image_files = [image_file]
file_extension = get_file_extension(image_file.filename)
if file_extension == '.pdf':
image_files = split_files(image_file)
texts = [get_text(image_file) for image_file in image_files]
text = '\n\n'.join(texts)
response = get_rag_response(text, is_landlord, user_question)
return {"result": response}
def get_file_extension(filename):
_, file_extension = os.path.splitext(filename)
return file_extension
def split_files(image_file):
image_files = []
images = convert_from_bytes(image_file.file.read())
for i, image in enumerate(images):
img_byte_arr = io.BytesIO()
image.save(img_byte_arr, format='JPEG')
img_byte_arr.seek(0)
jpg_file = UploadFile(
filename=f"page_{i + 1}.jpg",
file=img_byte_arr,
)
jpg_file.size = len(img_byte_arr.getvalue())
jpg_file.headers = Headers({
"content-disposition": f'form-data; name="image_file"; filename="page_{i + 1}.jpg"',
})
image_files.append(jpg_file)
return image_files
def get_text(image_file):
request_json = {
'images': [
{
'format': 'jpg',
'name': 'demo'
}
],
'requestId': str(uuid.uuid4()),
'version': 'V2',
'timestamp': int(round(time.time() * 1000))
}
payload = {'message': json.dumps(request_json).encode('UTF-8')}
files = [
('file', image_file.file)
]
headers = {
'X-OCR-SECRET': os.environ["CLOVA_OCR_SECRET_KEY"]
}
response = requests.request("POST", os.environ["CLOVA_OCR_API_URL"], headers=headers, data = payload, files = files)
result = response.json()
text = ""
for field in result['images'][0]['fields']:
text += field['inferText']
if field['lineBreak']:
text += '\n'
else:
text += ' '
return text
# uvicorn main:app --host 0.0.0.0 --port 8000
# http://localhost:8000/docs