pipeline_http_client.py 2.9 KB
Newer Older
L
LDOUBLEV 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
# Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

import numpy as np
import requests
import json
import base64
import os

T
tink2123 已提交
21
import argparse
22 23 24 25 26 27


def str2bool(v):
    return v.lower() in ("true", "t", "1")


T
tink2123 已提交
28 29
parser = argparse.ArgumentParser(description="args for paddleserving")
parser.add_argument("--image_dir", type=str, default="../../doc/imgs/")
30 31
parser.add_argument("--det", type=str2bool, default=True)
parser.add_argument("--rec", type=str2bool, default=True)
T
tink2123 已提交
32 33
args = parser.parse_args()

L
LDOUBLEV 已提交
34 35 36 37 38

def cv2_to_base64(image):
    return base64.b64encode(image).decode('utf8')


A
andyjpaddle 已提交
39 40 41 42 43
def _check_image_file(path):
    img_end = {'jpg', 'bmp', 'png', 'jpeg', 'rgb', 'tif', 'tiff', 'gif'}
    return any([path.lower().endswith(e) for e in img_end])


T
tink2123 已提交
44
url = "http://127.0.0.1:9998/ocr/prediction"
T
tink2123 已提交
45 46
test_img_dir = args.image_dir

A
andyjpaddle 已提交
47 48 49 50 51 52 53 54 55 56 57 58 59
test_img_list = []
if os.path.isfile(test_img_dir) and _check_image_file(test_img_dir):
    test_img_list.append(test_img_dir)
elif os.path.isdir(test_img_dir):
    for single_file in os.listdir(test_img_dir):
        file_path = os.path.join(test_img_dir, single_file)
        if os.path.isfile(file_path) and _check_image_file(file_path):
            test_img_list.append(file_path)
if len(test_img_list) == 0:
    raise Exception("not found any img file in {}".format(test_img_dir))

for idx, img_file in enumerate(test_img_list):
    with open(img_file, 'rb') as file:
L
LDOUBLEV 已提交
60
        image_data1 = file.read()
T
tink2123 已提交
61
    # print file name
T
tink2123 已提交
62
    print('{}{}{}'.format('*' * 10, img_file, '*' * 10))
L
LDOUBLEV 已提交
63 64 65

    image = cv2_to_base64(image_data1)

T
tink2123 已提交
66 67
    data = {"key": ["image"], "value": [image]}
    r = requests.post(url=url, data=json.dumps(data))
T
tink2123 已提交
68 69 70 71 72
    result = r.json()
    print("erro_no:{}, err_msg:{}".format(result["err_no"], result["err_msg"]))
    # check success
    if result["err_no"] == 0:
        ocr_result = result["value"][0]
73 74 75 76 77 78 79 80 81 82 83
        if not args.det:
            print(ocr_result)
        else:
            try:
                for item in eval(ocr_result):
                    # return transcription and points
                    print("{}, {}".format(item[0], item[1]))
            except Exception as e:
                print(ocr_result)
                print("No results")
                continue
T
tink2123 已提交
84

T
tink2123 已提交
85 86 87 88
    else:
        print(
            "For details about error message, see PipelineServingLogs/pipeline.log"
        )
A
andyjpaddle 已提交
89
print("==> total number of test imgs: ", len(test_img_list))