2026年7月9日 周四晚上19:30,报名腾讯会议了解“如何构建自进化的动态知识库(Brain)”(限30人)
免费POC, 零成本试错
FDE知识库

FDE知识库

学习大模型的前沿技术与行业落地应用


收藏

dify案例分享-基于多模态模型的发票识别

发布日期:2024-11-08 07:18:09 浏览次数: 6220
作者:wwzhouhui

微信搜一搜,关注“wwzhouhui”

1 什么是dify

Dify是一个开源的大语言模型(LLM)应用开发平台,旨在简化和加速生成式AI应用的创建和部署。它结合了后端即服务(Backend as Service, BaaS)和LLMOps的理念,使开发者能够快速搭建生产级的AI应用。

Dify的核心功能包括:

  1. 低代码/无代码开发:Dify提供了一个用户友好的界面,通过可视化的方式允许开发者轻松定义Prompt、上下文和插件等,无需深入底层技术细节。

  2. 模块化设计:采用模块化的设计,每个模块都有清晰的功能和接口,可以根据需求选择性地使用。

  3. 丰富的功能组件:包括AI工作流、RAG管道、Agent、模型管理、可观测性功能等,帮助开发者从原型到生产的全过程。

  4. 支持多种大语言模型:已支持OpenAI GPT系列等模型,并计划进一步扩展。

  5. 数据处理和特征工程工具:提供了数据清洗、特征选择、特征变换等功能,帮助开发者更好地准备数据。

  6. 集成外部知识源:允许自定义API接入外部知识源,让大型语言模型深入理解企业知识和业务。

此外,Dify还具有以下特点:

  • 面向各种技术背景的开发者:即使是没有编程基础的用户也能快速上手并参与到AI应用的定义和数据运营过程中。

  • 开源和社区支持:作为一个开源项目,Dify在GitHub上有活跃的社区支持,鼓励用户贡献和分享经验。

dify本身集成第三方工具和工作流。

目前官方最新dify 升级了0.10.1版本。目前该版本已经支持文件上传功能,所以我就给大家介绍一下带文件上传功能的发票识别。

2.什么是硅基流动

硅基流动是一家专注于人工智能基础设施和生成式AI技术的初创公司。硅基流动是致力于构建可扩展、标准化且高性能的生成式AI计算基础设施平台,提供包括SiliconCloud(模型云服务平台)、SiliconLLM(大型语言模型推理引擎)和OneDiff(高性能文本到图像/视频加速库)在内的多种软件解决方案。

公司的网站https://siliconflow.cn

目前公司有三个产品siliconCloud、siliconLLm、OneDiff

该公司提供市面上主流模型,而且最关键是免费。

 免费的模型涵盖文本生成、向量&重排序模型、图片生成、多模态大模型 等各种模型。提供一站式模型服务,这个比较爽。

目前新户注册送14块钱,大家可以通过我提供分析网址连接来感受这个免费的api模型服务。https://cloud.siliconflow.cn/i/e0f6GCrN

3 硅基流动功能介绍

注册登录后我们就可以进入体验中心

 我们可以在右边的模型下拉列表中选择免费或则收费的模型

   文本类模型还是蛮丰富的。

   文生图和图生图 也支持目前市面主流图像生成模型(FLUX.1-dev 、FLUX.1-schnell、stable-diffusion-3-medium、stable-diffusion-xl-base-1.0、stable-diffusion-2-1、sd-turbo、sdxl-turbo、SDXL-Lightning)

 其他使用方法这里就不过多介绍了。

4 硅基流动创建API

登录https://cloud.siliconflow.cn/account/ak,账号管理,点击新建API秘钥

这个创建的秘钥记得保存,后面流程中会用到。

5 dify创建发票识别机器人

5.1 模型设置

登录dify  点击右上角设置-模型供应商

找到硅基流动,输入步骤4上创建的API

关于硅基流动多模态模型设置。这里我们需要注意目前硅基流动增加多模态识别模型.dify功能目前还不支持关于硅基流动多模态模型的设置,所以我们需要借助标准OpenAI-API-compatible 来设置这个多模态模型

目前硅基支持以下几种多模态模型

点击 OpenAI-API-compatible,添加模型

这里我们设置一下硅基流动多模态模型的配置,这里我们就以Qwen/Qwen2-VL-72B-Instruct 为案例给大家介绍,大家可以看我下面的截图设置

  其他的和之前传统的llm模型设置一样,这里注意地方就是多模态VISION这个需要设置。点击保存完成模型设置。

5.2创建工作流或者chatflow

接着来到Dify中按下图顺序依次点击并点击创建(注:chatflow和工作流配置基本差不多,下面我们就以chatflow讲解)

 

5.2.1开始

      开始节点点开后我们需要添加一个文件上传输入参数。点击开始节点输入字段,点击右边的“+”

     

我们选择单个文件,输入变量名称、支持的文件类型我们这里就选择图片。其他都可以默认,输入完成后,点击保存按钮

以上步骤完成开始节点设置。

5.2.2文档提取器

 接下来我们在工作流画布中,选择文档提取器和开始节点连接,去掉llm和开始节点连接

 

 

我们在文档提取器,输入变量中选中 sys.files 变量

5.2.3 llm

  接下来我们将文档提取器的连接线和llm大语言模型连接。然后按照以下几个步骤设置

 1.模型选择,模型我们在模型下拉列表中选择自定义OpenAI-API-compatible  Qwen/Qwen2-VL-72B-Instruct模型;模型最大标记4096

 2.上下文,这里设置开始节点file 属性值

 3.SYSTEM 提示词 我们输入如下内容

请提取这张照片的内容,其中内容格式‘机器编号’、‘发票代码’、‘发票号码’、‘开票日期’、‘校 验 码’、‘购买方名称’、‘购买方纳税人识别号’、‘购买方地 址、电 话’、‘开户行及账号’、‘货物或应税劳务、服务名称’、‘规格型号’、‘单 位’、‘数 量’、‘单 价’、‘金 额’、‘税率’、‘税 额’、‘价税合计(大写)’、‘价税合计(小写)’、‘销售方名称’、‘销售方纳税人识别号’、‘销售方地 址、电 话’、‘销售方地 址、电 话’、‘开户行及账号’、‘备注’、‘收款人’、‘复核’、‘开票人’ 字段返回信息,返回的结果信息以json格式返回

4.视觉 点击右边按钮开启多模态

5  视觉输入变量  选择节点filefiles 变量

以上完成llm模型的设置

5.2.4 直接回复

接下来我们将LLM模型连接到直接回复的输出节点。

这个地方设置比较简单,在回复设置一下llm text文本输出以及 开始节点file 输出,这样设置后。就会将发票提取的票面信息以json格式的文本信息返回,并将上传的发票图片信息一并返回给用户

通过以上方式我们就初步完成了整个chatflow工作流。

完整的dsl 如下

app:
description: ''
icon: ?
icon_background: '#FFEAD5'
mode: advanced-chat
name: 增值税发票提取小工具chatflow
use_icon_as_answer_icon: false
kind: app
version: 0.1.2
workflow:
conversation_variables: []
environment_variables: []
features:
 file_upload:
   allowed_file_extensions:
   - .JPG
   - .JPEG
   - .PNG
   - .GIF
   - .WEBP
   - .SVG
   allowed_file_types:
   - image
   allowed_file_upload_methods:
   - local_file
   - remote_url
   enabled: false
   image:
     enabled: false
     number_limits: 3
     transfer_methods:
     - local_file
     - remote_url
   number_limits: 3
 opening_statement: ''
 retriever_resource:
   enabled: true
 sensitive_word_avoidance:
   enabled: false
 speech_to_text:
   enabled: false
 suggested_questions: []
 suggested_questions_after_answer:
   enabled: false
 text_to_speech:
   enabled: false
   language: ''
   voice: ''
graph:
 edges:
 - data:
     sourceType: llm
     targetType: answer
   id: llm-answer
   source: llm
   sourceHandle: source
   target: answer
   targetHandle: target
   type: custom
 - data:
     isInIteration: false
     sourceType: start
     targetType: document-extractor
   id: 1729851066338-source-1729851603790-target
   source: '1729851066338'
   sourceHandle: source
   target: '1729851603790'
   targetHandle: target
   type: custom
   zIndex: 0
 - data:
     isInIteration: false
     sourceType: document-extractor
     targetType: llm
   id: 1729851603790-source-llm-target
   source: '1729851603790'
   sourceHandle: source
   target: llm
   targetHandle: target
   type: custom
   zIndex: 0
 nodes:
 - data:
     desc: ''
     selected: false
     title: 开始
     type: start
     variables:
     - allowed_file_extensions: []
       allowed_file_types:
       - image
       allowed_file_upload_methods:
       - local_file
       - remote_url
       label: file
       max_length: 48
       options: []
       required: true
       type: file
       variable: file
   height: 90
   id: '1729851066338'
   position:
     x: 0
     y: 277
   positionAbsolute:
     x: 0
     y: 277
   selected: true
   sourcePosition: right
   targetPosition: left
   type: custom
   width: 244
 - data:
     context:
       enabled: true
       variable_selector:
       - '1729851066338'
       - file
     desc: ''
     memory:
       query_prompt_template: ''
       role_prefix:
         assistant: ''
         user: ''
       window:
         enabled: false
         size: 10
     model:
       completion_params:
         temperature: 0.7
       mode: chat
       name: Qwen/Qwen2-VL-72B-Instruct
       provider: openai_api_compatible
     prompt_template:
     - id: 994d57b8-32bc-45cd-b30a-4a1481553627
       role: system
       text: 请提取这张照片的内容,其中内容格式‘机器编号’、‘发票代码’、‘发票号码’、‘开票日期’、‘校 验 码’、‘购买方名称’、‘购买方纳税人识别号’、‘购买方地
         址、电 话’、‘开户行及账号’、‘货物或应税劳务、服务名称’、‘规格型号’、‘单 位’、‘数 量’、‘单 价’、‘金 额’、‘税率’、‘税
         额’、‘价税合计(大写)’、‘价税合计(小写)’、‘销售方名称’、‘销售方纳税人识别号’、‘销售方地 址、电 话’、‘销售方地 址、电 话’、‘开户行及账号’、‘备注’、‘收款人’、‘复核’、‘开票人’
         字段返回信息,返回的结果信息以json格式返回
     selected: false
     title: LLM
     type: llm
     variables: []
     vision:
       configs:
         detail: high
         variable_selector:
         - '1729851066338'
         - file
       enabled: true
   height: 98
   id: llm
   position:
     x: 589
     y: 309
   positionAbsolute:
     x: 589
     y: 309
   selected: false
   sourcePosition: right
   targetPosition: left
   type: custom
   width: 244
 - data:
     answer: '{{#llm.text#}}'
     desc: ''
     selected: false
     title: 直接回复
     type: answer
     variables: []
   height: 103
   id: answer
   position:
     x: 1004
     y: 270
   positionAbsolute:
     x: 1004
     y: 270
   selected: false
   sourcePosition: right
   targetPosition: left
   type: custom
   width: 244
 - data:
     desc: ''
     is_array_file: true
     selected: false
     title: 文档提取器
     type: document-extractor
     variable_selector:
     - sys
     - files
   height: 94
   id: '1729851603790'
   position:
     x: 304
     y: 285
   positionAbsolute:
     x: 304
     y: 285
   selected: false
   sourcePosition: right
   targetPosition: left
   type: custom
   width: 244
 viewport:
   x: -165.00000000000023
   y: 102.99999999999994
   zoom: 1.0000000000000002

5.3chatflow调试及发布

接下来我们点击工作流预览测试一下。

我们点击从本地文件上传,找一张增值税普通发票验证一下。

我们点开工作流看到流程节点是从开始-文档提取器-LLM-直接回复 4个流程节点,并且每个流程执行的时间都能详细展开看到。最后用户返回了发票提取的票面信息返回json值了。目前这个工作流适合增值税专用发票和增值税普通发票识别,如果大家需要识别全电发票,火车票还有其他类发票只要修改llm模型中的提示词即可。

目前我测试下来Qwen/Qwen2-VL-72B-Instruct模型的发票票面ocr识别率还是蛮准的,几乎是100%识别。

接下来我们可以将这个工作流发布或则以第三方接口形式对外提供

5.3.1发布

点击工作流左上角发布按钮对外提供发布

我们将分享的地址发送给其他小伙伴

我们点击 start chat 就可以使用了。

6 总结

 目前dify官方最新版本升级到0.10.1版本 开始支持文件上传,图片上传等功能了。另外硅基流动大概在2024年10月18日上线了阿里和书生的多模态模型。今天就带大家感受一下dify新功能已经硅基流动的新模型整合。目前该工作流还只支持一种发票票面识别功能还比较单一,还不能识别更多发票。比如(火车票、手撕票、出租车票、医疗报销单等等)。dify工作流程这块有很多流程控制 通过这些流程控制其实是可以实现以上功能的,感兴趣的小伙伴可以持续关注我的文章,我后期会增加这块功能打造一个更完善的基于多模型模型的发票识别小助手。今天的分享就到这里,我们下个文章见。


53AI,企业落地大模型首选服务商

产品:场景落地咨询+大模型应用平台+行业解决方案

承诺:免费POC验证,效果达标后再合作。零风险落地应用大模型,已交付160+中大型企业

联系我们

售前咨询
186 6662 7370
预约演示
185 8882 0121

微信扫码

添加专属顾问

回到顶部

加载中...

扫码咨询

扫码登录
登录即表示您同意《53AI网站服务协议》
服务协议

欢迎您使用【53AI 官方网站】(以下简称“本网站”或“我们”)。本《会员服务协议》(以下简称“本协议”)是您(以下简称“会员”或“用户”)与【深圳市博思协创网络科技有限公司】之间关于注册、登录及使用本网站会员服务所订立的法律协议。

在您注册或登录前,请务必审慎阅读、充分理解各条款内容,特别是免除或限制责任的条款、知识产权条款、争议解决条款等。此类条款将以加粗形式提示您注意。 当您通过微信公众号授权、手机验证码验证或其他方式成功登录本网站时,即视为您已完全理解并同意接受本协议的全部内容。

一、 定义

本网站:指由【深圳市博思协创网络科技有限公司】运营的,域名为【53ai.com】的网站及相关移动端页面。

会员服务:指本网站向注册会员提供的知识库文章查阅、内容检索及其他相关增值服务。

知识库内容:指本网站发布的包括但不限于文字、图表、数据、研究报告、行业分析等数字化内容资源。

二、 账号注册与登录

登录方式:本网站支持以下登录方式,您可根据实际情况选择:

微信公众号授权登录:您同意将您的微信OpenID信息授权给本网站,用于创建或关联会员账号。

手机验证码登录:您需提供真实有效的手机号码,并通过短信验证码完成身份验证与登录/注册。

账号安全:您的账号仅限您本人使用,禁止赠与、借用、租用、转让或售卖。因您保管不善导致的账号被盗、密码泄露等损失,由您自行承担。

实名认证:根据相关法律法规要求,我们可能要求您在特定功能下完成实名认证。如您拒绝提供,可能无法使用部分或全部服务。

未成年人保护:若您未满18周岁,请在法定监护人的陪同下阅读本协议,并在征得监护人同意后使用本服务。

三、 服务内容与规范

知识库查阅权限:会员登录后,有权按照其会员等级对应的权限范围,在线浏览、检索本网站知识库中的相关文章及内容。

服务变更:我们有权根据业务发展需要,调整、变更或终止部分服务内容,并将以网站公告、公众号消息等方式提前通知。

禁止行为:您在使用服务时不得实施以下行为:

利用技术手段批量爬取、下载、转存知识库内容;

将知识库内容用于商业目的或未经授权地向第三方传播;

干扰本网站正常运行或侵犯其他用户合法权益;

发布违法违规信息或从事违反公序良俗的活动。

四、 知识产权声明

权利归属:本网站知识库中的排版设计、软件代码等内容的知识产权均归【公司全称】或原权利人所有,受《中华人民共和国著作权法》等法律保护。

有限许可:本网站授予会员一项非独占、不可转让、不可转授权的普通许可,仅限于个人学习、研究之目的在线查阅知识库内容。

侵权追责:未经书面许可,任何单位或个人不得以任何形式复制、转载、摘编、镜像、汇编或以其他方式使用上述内容。一经发现,我们保留追究其法律责任的权利。

五、 个人信息保护

我们重视对您个人信息的保护。关于我们如何收集、使用、存储和保护您的个人信息,请单独阅读 《隐私政策》。

您通过微信公众号授权或手机号验证所提供的信息,我们将严格按照《个人信息保护法》的规定处理,仅用于身份识别、服务提供及安全验证等必要用途。

您可以随时通过网站设置或联系客服行使查阅、更正、删除个人信息及撤回授权同意的权利。

六、 免责声明

内容准确性:知识库内容仅供参考,不构成专业建议。我们不对其完整性、准确性、时效性作任何明示或暗示的保证,您应自行判断并承担使用风险。

不可抗力:因自然灾害、政策法规变化、网络故障、第三方平台接口异常(如微信接口维护、运营商短信通道故障)等不可抗力导致的服务中断或延迟,我们不承担违约责任。

第三方链接:本网站可能包含指向第三方网站的链接,该等网站的内容和服务不受我们控制,请您自行甄别风险。

七、 违约责任

如您违反本协议约定,我们有权视情节采取警告、限制功能、暂停服务、注销账号等措施,并保留要求赔偿损失的权利。

如因您的违约行为导致我们遭受行政处罚、第三方索赔或商誉损失,您应承担全部赔偿责任(包括但不限于罚款、赔偿金、律师费、公证费等)。

八、 法律适用与争议解决

本协议的订立、执行和解释均适用中华人民共和国大陆地区法律。

因本协议产生的或与本协议有关的任何争议,双方应友好协商解决;协商不成的,任何一方均可向【公司所在地】有管辖权的人民法院提起诉讼。

九、 其他

本协议构成双方就本服务达成的完整协议,取代此前任何口头或书面约定。

本协议任一条款被认定为无效或不可执行的,不影响其他条款的效力。

我们对本协议享有最终解释权,并在法律允许的范围内保留随时修改的权利。修改后的协议一经公布即生效,继续使用服务即视为同意修订内容。


已查阅