在Windows环境下一键部署PaddleOCR的WEBAPI功能详解及实例

PaddleOCR是一款由百度开源的光学字符识别(OCR)工具,它可以识别多种格式的图像文件,并将其转换为文本。PaddleOCR的WEBAPI功能可以让我们在Web应用中直接调用PaddleOCR的识别功能,无需在服务器端进行复杂的处理。本文将详细介绍如何在Windows环境下一键部署PaddleOCR的WEBAPI功能,并提供一个详细的实例。
在这里插入图片描述

一、环境准备

首先,我们需要安装Python环境。推荐使用Anaconda,因为它包含了许多常用的科学计算库,如numpy、pandas等。下载地址:https://www.anaconda.com/products/distribution

安装完成后,打开命令行窗口,输入以下命令安装PaddleOCR:

pip install paddlepaddle paddleocr

二、部署PaddleOCR的WEBAPI

将以下代码另存为bat。然后运行。

@echo off
COLOR 2F
title 
echo 本脚本演示如何在window境下一键部署PaddleOCR的WEBAPI功能。
echo 待脚本执行完后,将自动开一个OCR服务。url=127.0.0.1:5000/PaddleOCR/DetectText
echo 检测PYTHON安装
python -V
python -m pip install --upgrade pip

pip3 install opencv-python==4.5.5.64
echo  开始安装PaddleOCR
pip3 install  paddleocr

echo 安装PaddleOCR的依赖预测库
pip3 install paddlepaddle
echo 安装Flask
pip3 install Flask
echo 安装DateTime
pip3 install DateTime

set port=5000
set filename=PaddleOCRAPI.py
@echo off
del %filename%
echo import io >> %filename%
echo from pickle import DICT >> %filename%
echo import paddleocr >> %filename%
echo import json >> %filename%
echo import base64 >> %filename%
echo import DateTime >> %filename%
echo from flask import Flask, request,jsonify   >> %filename%
echo import numpy as np >> %filename%
echo from PIL import Image >> %filename%
echo app=Flask(__name__) >> %filename%
echo app.config['JSON_AS_ASCII']=False >> %filename%
echo @app.route("/PaddleOCR/DetectText",methods=["POST"]) >> %filename%
echo def PaddleOCR(): >> %filename%
echo     if(request.data==""): >> %filename%
echo         return APIResult.Error("request data is null") >> %filename%
echo     data=json.loads(request.data) >> %filename%
echo     imgbyte=base64.b64decode(data) >> %filename%
echo     image=io.BytesIO(imgbyte) >> %filename%
echo     temp= Image.open(image) >> %filename%
echo     img=np.array(temp)[:,:,:3] >> %filename%
echo     info= ppocr.ocr(img) >> %filename%
echo     result={"TextBlocks":[]} >> %filename%
echo     for textblocks in info: >> %filename%
echo         textBlock={"Points":[],"Text":""} >> %filename%
echo         for tk in textblocks[0]: >> %filename%
echo               point={"x":str(tk[0]),"y":str(tk[1])} >> %filename%
echo               textBlock["Points"].append(point)  >> %filename%
echo         textBlock["Text"]=textblocks[1][0] >> %filename%
echo         result["TextBlocks"].append(textBlock) >> %filename%
echo     print(result) >> %filename%
echo     return jsonify(result) >> %filename%
echo     
echo def main(): >> %filename%
echo     global ppocr; >> %filename%
echo     ppocr=paddleocr.PaddleOCR(use_gpu=False); >> %filename%
echo     app.run(debug=True,host="0.0.0.0",port=%port%) >> %filename%
echo if __name__=="__main__": >> %filename%
echo     main(); >> %filename%
call %filename%

现在,我们已经成功部署了PaddleOCR的WEBAPI。你可以通过发送包含图片文件的POST请求来测试它。例如,你可以使用Postman或者curl命令来发送请求:

```bash
curl -X POST -F "file=@path/to/your/image.jpg" 127.0.0.1:5000/PaddleOCR/DetectText

三、实例分析

假设我们有一个名为example.jpg的图片文件,我们希望使用PaddleOCR的WEBAPI来识别其中的文字。我们可以按照以下步骤操作:

  1. 打开Postman或者curl命令行窗口。
  2. 输入以下命令发送POST请求:
curl -X POST -F "file=@path/to/your/example.jpg" 127.0.0.1:5000/PaddleOCR/DetectText
  1. 查看返回的结果。如果一切正常,你应该能看到识别出的文字列表。

总结

通过以上步骤,我们已经成功地在Windows环境下部署了PaddleOCR的WEBAPI功能。这个功能可以让我们轻松地在Web应用中集成OCR功能,大大提高了我们的工作效率。希望这篇文章能帮助你更好地理解和使用PaddleOCR的WEBAPI功能。

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在IIS上部署ASP.NET Core Web API项目及Swagger可以按照以下步骤进行: 1. 首先,我们需要确保已经在本地系统上安装了ASP.NET Core Runtime和ASP.NET Core Hosting Bundle,以便在IIS中运行ASP.NET Core应用程序。 2. 在Visual Studio中,打开你的ASP.NET Core Web API项目。确保项目已经设置为IIS Express作为本地开发服务器。 3. 在项目根目录下的`Properties`文件夹中找到`launchsettings.json`文件,检查并确保该文件中已经配置了`applicationUrl`为`http://localhost:{port}/`,其中`port`为你希望的端口号。 4. 在Visual Studio的顶部菜单中,找到 `Build` -> `Publish {YourProjectName}`,选择发布目标为`Folder`,点击 `Publish`。 5. 在弹出的窗口中选择一个输出文件夹,用于存储发布项目的文件。 6. 打开发布文件夹,在该文件夹中应该有一个名为`web.config`的文件。双击打开该文件,确保其中有以下代码片段: ```xml <aspNetCore processPath="dotnet" arguments=".\{YourProjectName}.dll" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" forwardWindowsAuthToken="false" /> ``` 7. 打开IIS管理器,右点击`Sites`节点,选择`Add Website`。填写网站名称以及物理路径为刚刚发布项目的目录。 8. 对于应用程序池,选择一个合适的.NET CLR版本和托管管道模式(例如:.NET CLR版本为No Managed Code,托管管道模式为集成)。 9. 在网站的右侧,找到`Authentication`,禁用匿名身份验证并启用Windows身份验证。 10. 重新启动IIS。 11. 现在,我们可以在浏览器中访问`http://localhost:{port}`,应该能够看到你的ASP.NET Core Web API已经在IIS上成功部署。 12. 最后,要在部署的项目中添加Swagger,可以通过NuGet包管理器,添加`Swashbuckle.AspNetCore`包。 13. 在`Startup.cs`文件的`ConfigureServices`方法中,添加以下配置: ```csharp services.AddSwaggerGen(c => { c.SwaggerDoc("v1", new OpenApiInfo { Title = "API", Version = "v1" }); }); ``` 14. 在`Startup.cs`文件的`Configure`方法中,添加以下代码: ```csharp app.UseSwagger(); app.UseSwaggerUI(c => { c.SwaggerEndpoint("/swagger/v1/swagger.json", "API v1"); }); ``` 15. 重新发布并重新启动IIS,现在你的ASP.NET Core Web API应该在IIS上部署并且通过Swagger可以浏览和调用你的API接口。 以上就是在IIS上部署ASP.NET Core Web API项目及Swagger的步骤。请注意,确保按照正确的顺序执行每一步,并根据自己的项目配置进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程式员阿波

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值