• C# 10分钟完成百度图片提取文字(文字识别)——入门篇


      现在图片文字识别已经很成熟了,比如qq长按图片,点击图片识别就可以识别图片的文字,将不认识的、文字数量大的、或者不能赋值的值进行二次可复制功能。

    我们现在就基于百度Ai开放平台进行个人文字识别,demo使用的是C#控制台应用程序,后续有需要的可以嫁接到指定项目中使用,比如提供选择图片,点击识别,

    获取返回的值。废话不多说,上干货:


    总体为:

    1. 注册百度账号api,创建自己的应用;
    2. 创建vs控制台应用程序,引入动态链接库;
    3. 编写代码调试,效果图查看;
    4. 总结。

    1、创建百度AI文字识别应用

      在百度AI开放平台中,登录自己的百度账号,点击“文字识别”服务中的“通用场景文字识别”,选择“创建应用”,填好应用名称,选择应用类型,填好应用描述,这样就创建好了“通用场景文字识别”服务。

    具体不废话,不知道的小伙伴可以移步看这里:C# 10分钟完成百度人脸识别——入门篇

    创建完成后会生成APPID、APP Key、Secret Key,这些是关键内容,后面要用。

    2、创建VS控制台应用程序,引入动态链接库

    首先我们创建一个VS控制台应用程序,这里就不详细说明。

    然后引入百度Baidu.AI动态链接库,步骤如下,小编使用2017,所以直接在NuGet中搜索Baidu.AI安装即可。

    安装文字识别 C# SDK

    C# SDK 现已开源! https://github.com/Baidu-AIP/dotnet-sdk

    ** 支持平台:.Net Framework 3.5 4.0 4.5, .Net Core 2.0 **

    方法一:使用Nuget管理依赖 (推荐)

    在NuGet中搜索 Baidu.AI,安装最新版即可。

    packet地址 https://www.nuget.org/packages/Baidu.AI/

    方法二:下载安装

    文字识别 C# SDK目录结构

    Baidu.Aip
        ├── net35
        │   ├── AipSdk.dll             // 百度AI服务 windows 动态库
        │   ├── AipSdk.xml             // 注释文件
        │   └── Newtonsoft.Json.dll    // 第三方依赖
        ├── net40
        ├── net45
        └── netstandard2.0
            ├── AipSdk.deps.json
            └── AipSdk.dll
    

    如果需要在 Unity 平台使用,可引用工程源码自行编译。

    安装

    1.在官方网站下载C# SDK压缩工具包。

    2.解压后,将 AipSdk.dll 和 Newtonsoft.Json.dll 中添加为引用。


    3、编写代码调试,效果图查看

      创建一个空文件夹,命名为Image,存一个张有文字的图片,做调试。

    在Program.cs中编写代码,代码编写如下,可以直接拷贝进行调试。

    using System;
    using System.Collections.Generic;
    using System.IO;
    using System.Linq;
    using System.Net;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace Recognition
    {
       public class Program
        {
           static void Main(string[] args)
            {
                //AK/SK
                var API_KEY = "FGPi0QpCbZxZxBaN6dvqt87X";
                var SECRET_KEY = "HunNq6XsLjF3a7aCAuirVaVQO7CKBuwW";
    
                var client = new Baidu.Aip.Ocr.Ocr(API_KEY, SECRET_KEY);
                client.Timeout = 60000;  // 修改超时时间
    
    
                var image = File.ReadAllBytes("E:\Work Demo\图片提取文字\Recognition\Recognition\Image\img.jpg");
                var url = "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1564654456007&di=7832dd6f515e654bdf5074e47b6803b1&imgtype=0&src=http%3A%2F%2Fpic.962.net%2Fup%2F2018-5%2F2018527102938219310.jpg";
                
                // 调用通用文字识别, 图片参数为本地图片,可能会抛出网络等异常,请使用try/catch捕获
                //用户向服务请求识别某张图中的所有文字
                var result = client.GeneralBasic(image);        //本地图图片
                //var result = client.GeneralBasicUrl(url);     //网络图片
                //var result = client.Accurate(image);          //本地图片:相对于通用文字识别该产品精度更高,但是识别耗时会稍长。
    
                //var result = client.General(image);           //本地图片:通用文字识别(含位置信息版)
                //var result = client.GeneralUrl(url);          //网络图片:通用文字识别(含位置信息版)
    
                //var result = client.GeneralEnhanced(image);   //本地图片:调用通用文字识别(含生僻字版)
                //var result = client.GeneralEnhancedUrl(url);  //网络图片:调用通用文字识别(含生僻字版)
    
                //var result = client.WebImage(image);          //本地图片:用户向服务请求识别一些背景复杂,特殊字体的文字。
                //var result = client.WebImageUrl(url);         //网络图片:用户向服务请求识别一些背景复杂,特殊字体的文字。
    
                Console.WriteLine(result);
            }
        }
    }

    下面注释了的每一行都是一种识别,更多识别请看官网:https://ai.baidu.com/docs#/OCR-Csharp-SDK/top

    调用两个,一个精准,一个不精准,先看精准的:

    调用的是:var result = client.GeneralBasic(image);,最后一个字没识别出来

     我的图片文字是“做个快乐读书人”,最后的“人”没识别出来,我们换一个能后识别复杂背景的,

    调用的是:var result = client.GeneralEnhanced(image);


    4、总结

       具体业务使用看场景使用不同的接口即可。

    这只是一个简单的识别,针对不能赋值、文字繁多、不认识的字都可以做一个简单的文字识别,更多内容需要大家去摸索入坑

    拜拜,下次再见咯!

    欢迎关注订阅我的微信公众平台【熊泽有话说】,更多好玩易学知识等你来取
    作者:熊泽-学习中的苦与乐
    公众号:熊泽有话说
    出处:https://www.cnblogs.com/xiongze520/p/11283484.html
    创作不易,任何人或团体、机构全部转载或者部分转载、摘录,请在文章明显位置注明作者和原文链接。  

     

  • 相关阅读:
    价值理论的出发点和落脚点都是人--以人为本
    价值理论是人类决策和行为的标尺
    事实判断和价值判断
    什么是价值理论?---人们认识世界和改造世界的过程可分解为四个基本阶段
    大人只看利弊 小孩才分对错
    为人处世、事实判断和价值判断皆不可少--人类认识客观事物的标尺:对错与利弊
    知行之间--价值与真理--行动的标尺
    事实判断与价值判断之间的桥梁就是人的需要
    10分钟梳理MySQL核心知识点
    postman设置环境变量,实现一套接口根据选择的环境去请求不同的url
  • 原文地址:https://www.cnblogs.com/xiongze520/p/11283484.html
Copyright © 2020-2023  润新知