C#用百度OCR识别图片文字

百度有直接的Nuget包引用非常的简单调用:

具体怎么用看说明文档就够了:

 

 

static void Main(string[] args)
        {
            GeneralBasicDemo();
        }

        public static void GeneralBasicDemo()
        {
           
            var API_KEY = "********";
            var SECRET_KEY = "*************";

            var client = new Baidu.Aip.Ocr.Ocr(API_KEY, SECRET_KEY);
            client.Timeout = 60000;  // 修改超时时间
            string img = @"E:\imgFile\15.jpg";

            var image = File.ReadAllBytes(img);
            // 调用通用文字识别(高精度版),可能会抛出网络等异常,请使用try/catch捕获
            // 如果有可选参数
            var options = new Dictionary<string, object>{
                                                             {"detect_direction", "true"},
                                                             {"probability", "true"}
                                                         };
            // 带参数调用通用文字识别(高精度版)
            var result = client.AccurateBasic(image, options);
            string str = string.Empty;
            var txts = (from obj in (JArray)result.Root["words_result"]
                        select (string)obj["words"]);
            //foreach (var r in txts)
            //{
            //    str += r+"\r\n";
            //}
            str = string.Join("\r\n", txts);
            Console.WriteLine(str);
            Console.ReadKey();
        }

需要注意的是返回的数据是JObject格式,搞了大半天后才拿到数据,类似键值对的方式,直接用linq获取即可;

posted @ 2021-09-08 16:12  点终将连成线  阅读(665)  评论(0编辑  收藏  举报