一文看懂增值税发票识别OCR:从技术原理到 API Java 示例代码接入

本文涉及的产品
票据凭证识别,票据凭证识别 200次/月
票证核验,票证核验 50次/账号
小语种识别,小语种识别 200次/月
简介: 一文看懂增值税发票识别OCR:从技术原理到 API Java 示例代码接入

引言

增值税发票识别OCR API是一项重要的技术创新,它在如今信息化的商业环境中发挥着重要作用。通过利用该API,企业和机构能够实现增值税发票的自动化识别和信息提取,从而在财务管理、票据核对、报销流程等方面带来许多好处。

本文将详细介绍增值税发票识别OCR API 的基本原理和工作流程以及应用场景,帮助读者更好地了解和使用这项技术。

技术原理

增值税发票识别OCR 的技术原理涉及图像处理和 OCR 技术。下面是增值税发票识别OCR 的一般技术原理:

1. 图像预处理

在识别发票之前,首先需要对输入的发票图像进行预处理,以提高后续字符识别的准确性。

这一步骤包括以下操作:

  • 灰度化:将彩色图像转换为灰度图像,减少颜色信息对字符识别的干扰。
  • 二值化:将灰度图像转换为二值图像,将图像分为黑白两色,使字符更加清晰可见。
  • 去噪:通过滤波和图像处理技术去除图像中的噪声,以减少对字符识别的影响。

2. 区域定位

在发票图像中,需要确定包含文本信息的区域,如发票代码、发票号码、开票日期、金额等。区域定位的目的是准确定位这些文本信息的位置,为后续的字符分割和识别做准备。

这一步骤可以通过图像处理技术和机器学习算法来实现,例如边缘检测、轮廓提取等。

3. 字符分割

在区域定位的基础上,将每个区域中的文本字符进行分割,将其单独提取出来,为后续的字符识别做准备。字符分割的目的是将文本区域中的字符划分为独立的单元,以便进行逐个字符的识别。

常见的字符分割方法包括基于像素的分割、基于连通区域的分割和基于投影的分割等。

4. 字符识别

在字符分割后,利用光学字符识别(OCR)技术对每个字符进行识别,将其转换为对应的可读文本。

OCR技术是通过训练好的模型来推测字符的识别结果,这些模型经过大量的训练,能够根据输入的字符图像特征,推测出最可能的字符。

OCR技术在识别字符时会考虑字符的形状、纹理、颜色等特征,并结合上下文信息进行推理和判断。

5. 结果输出

最后,将识别得到的字符信息组合成各个字段,包括发票基本信息、销售方和购买方信息、商品信息、价税信息等。提取得到的字段信息可以输出为结构化数据,方便后续的数据处理和应用。

应用场景

image.png

在程序中接入增值税发票识别OCR API

在 Java 程序中,我们可直接复制以下代码接入增值税发票识别OCR API,API 密钥可以在 APISpace 网站注册登录获取。

OkHttpClient client = new OkHttpClient().newBuilder().build();
MediaType mediaType = MediaType.parse("application/json");
RequestBody body = RequestBody.create(mediaType, "{"image":"","url":"https://data-apibee.apispace.com/license/16782741889795037be0f-2909-4f99-9dee-d8a8d46349cd","pdf":"","type":"0","pdf_page":""}");
Request request = new Request.Builder()
  .url("https://eolink.o.apispace.com/fapiao/addvaluedinvoiceOCR")
  .method("POST",body)
  .addHeader("X-APISpace-Token","试用 APISpace 平台提供的API 密钥")
  .addHeader("Authorization-Type","apikey")
  .addHeader("Content-Type","")
  .build();

Response response = client.newCall(request).execute();
System.out.println(response.body().string());

识别效果

识别图片:

返回示例:

{
    “result”: {
        “QRcode_content”: “01,01,330XXXX130,50XXXX51,1327.43,20200813,,86BA,”,
        “QRcode_location”: [
            [68, 77],
            [273, 77],
            [273, 281],
            [68, 281]
        ],
        “invoice_code”: “33XXXX4130”,
        “machine_code”: “”,
        “check_code”: “”,
        “title”: “浙江增值税专用发票”,
        “invoice_number”: “50XXXX51”,
        “print_invoice_code”: “3300194130”,
        “print_invoice_number”: “50708251”,
        “invoice_date”: “2020年08月13日”,
        “buyer_name”: “杭州XXXX有限公司”,
        “buyer_tax_number”: “91330101MA28X2CC84”,
        “buyer_contact_info”: “浙江省航XXXXXXXXXXX商铺0571-56279728”,
        “buyer_bank_account_info”: “航州联合XXXXXXXXXXX网下沙支行201000179490762”,
        “password_area”: “59/12<08-49>03>0->2<2-88XXXXXXXXXXXXXXXXX80-9/5-921-669/6<>8+90>7/64/58-10><6+2>050/7+1”,
        “total_amount_pretax”: “¥1327.43”,
        “total_tax”: “¥172.57”,
        “total_amount_inwords”: “壹仟伍佰圆整”,
        “total_amount”: “¥1500.00”,
        “seller_name”: “杭州乾XXXXXXXXX限公司”,
        “seller_tax_number”: “91330106MA2GNB0M08”,
        “seller_contact_info”: “杭州市西XXXXXXXXXX室15058921697”,
        “seller_bank_account_info”: “建设银行XXXXXXXXXXXXXX8300000571”,
        “payee”: “段国华”,
        “checker”: “段国华”,
        “payer”: “段国华”
    },
    “log_id”: “16710XXXXXXXX8447450712”
}

结语

增值税发票识别OCR API的出现为企业提供了一种高效、准确的发票识别和信息提取解决方案。通过图像预处理、区域定位、字符分割和字符识别等步骤,该 API 能够自动识别发票中的关键字段信息,并提供结构化的数据输出。

这项技术在财务管理、票据核对、报销流程、数据分析与统计以及自动化流程集成等多个应用场景中展现了巨大的潜力,有需要的小伙伴赶紧用起来吧~

相关文章
|
7天前
|
SQL Java API
使用Java Stream API简化集合操作
使用Java Stream API简化集合操作
|
6天前
|
监控 安全 Java
在Java中集成第三方API调用的最佳实践
在Java中集成第三方API调用的最佳实践
|
8天前
|
Java API
如何利用Java Stream API简化集合操作?
如何利用Java Stream API简化集合操作?
|
10天前
|
开发框架 Java API
Java中的REST API开发详解
Java中的REST API开发详解
|
15天前
|
Java API 开发者
RESTful API设计与实现:Java开发者指南
RESTful API设计与实现:Java开发者指南
|
12天前
|
XML Java API
使用Java构建RESTful API的最佳实践
使用Java构建RESTful API的最佳实践
|
12天前
|
Java API
Java中的日期和时间API详解
Java中的日期和时间API详解
|
14天前
|
Java 测试技术 API
Java详解 : API常用类
Java详解 : API常用类
|
13天前
|
Java API PHP
【亲测有效,官方提供】php版本企查查api接口请求示例代码,php请求企查查api接口,thinkphp请求企查查api接口
【亲测有效,官方提供】php版本企查查api接口请求示例代码,php请求企查查api接口,thinkphp请求企查查api接口
20 1
|
5天前
|
并行计算 Java 数据挖掘
Java面试题:解释Java中的Stream API及其操作
Java面试题:解释Java中的Stream API及其操作
10 0