---
comments: true
---
# 文档理解产线使用教程
## 1. 文档理解产线介绍
文档理解产线是基于视觉-语言模型(VLM)打造的先进文档处理技术,旨在突破传统文档处理的局限。传统方法依赖固定模板或预定义规则解析文档,而该产线借助VLM的多模态能力,仅需输入文档图片和用户问题,即可通过融合视觉与语言信息,精准回答用户提问。这种技术无需针对特定文档格式预训练,能够灵活应对多样化文档内容,显著提升文档处理的泛化性与实用性,在智能问答、信息提取等场景中具有广阔应用前景。本产线目前暂不支持对VLM模型的二次开发,后续计划支持。
文档理解产线中包含了文档类视觉语言模型模块,您可以根据下方的基准测试数据选择使用的模型。
### 1.1 模型基准测试数据
如果您更注重模型的精度,请选择精度较高的模型;如果您更在意模型的推理速度,请选择推理速度较快的模型;如果您关注模型的存储大小,请选择存储体积较小的模型。
> 推理耗时仅包含模型推理耗时,不包含前后处理耗时。
API参考
对于服务提供的主要操作:
- HTTP请求方法为POST。
- 请求体和响应体均为JSON数据(JSON对象)。
- 当请求处理成功时,响应状态码为
200,响应体的属性如下:
| 名称 |
类型 |
含义 |
logId |
string |
请求的UUID。 |
errorCode |
integer |
错误码。固定为0。 |
errorMsg |
string |
错误说明。固定为"Success"。 |
result |
object |
操作结果。 |
| 名称 |
类型 |
含义 |
logId |
string |
请求的UUID。 |
errorCode |
integer |
错误码。与响应状态码相同。 |
errorMsg |
string |
错误说明。 |
服务提供的主要操作如下:
对输入消息进行推理生成响应。
POST /document-understanding
说明 以上接口别名/chat/completion,openai兼容的接口
| 名称 |
类型 |
含义 |
是否必填 |
默认值 |
model |
string |
要使用的模型名称 |
是 |
- |
messages |
array |
对话消息列表 |
是 |
- |
max_tokens |
integer |
生成的最大token数 |
否 |
1024 |
temperature |
float |
采样温度 |
否 |
0.1 |
top_p |
float |
核心采样概率 |
否 |
0.95 |
stream |
boolean |
是否流式输出 |
否 |
false |
max_image_tokens |
int |
图像的最大输入token数 |
否 |
None |
messages中的每个元素为一个object,具有如下属性:
| 名称 |
类型 |
含义 |
是否必填 |
role |
string |
消息角色(user/assistant/system) |
是 |
content |
string或array |
消息内容(文本或图文混合) |
是 |
当content为数组时,每个元素为一个object,具有如下属性:
| 名称 |
类型 |
含义 |
是否必填 |
默认值 |
type |
string |
内容类型(text/image_url) |
是 |
- |
text |
string |
文本内容(当type为text时) |
条件必填 |
- |
image_url |
string或object |
图片URL或对象(当type为image_url时) |
条件必填 |
- |
当image_url为对象时,具有如下属性:
| 名称 |
类型 |
含义 |
是否必填 |
默认值 |
url |
string |
图片URL |
是 |
- |
detail |
string |
图片细节处理方式(low/high/auto) |
否 |
auto |
请求处理成功时,响应体的result具有如下属性:
| 名称 |
类型 |
含义 |
id |
string |
请求ID |
object |
string |
对象类型(chat.completion) |
created |
integer |
创建时间戳 |
choices |
array |
生成结果选项 |
usage |
object |
token使用情况 |
choices中的每个元素为一个Choice对象,具有如下属性:
| 名称 |
类型 |
含义 |
可选值 |
finish_reason |
string |
模型停止生成token的原因 |
stop(自然停止)
length(达到最大token数)
tool_calls(调用了工具)
content_filter(内容过滤)
function_call(调用了函数,已弃用) |
index |
integer |
选项在列表中的索引 |
- |
logprobs |
object | null |
选项的log概率信息 |
- |
message |
ChatCompletionMessage |
模型生成的聊天消息 |
- |
message对象具有如下属性:
| 名称 |
类型 |
含义 |
备注 |
content |
string | null |
消息内容 |
可能为空 |
refusal |
string | null |
模型生成的拒绝消息 |
当内容被拒绝时提供 |
role |
string |
消息作者角色 |
固定为"assistant" |
audio |
object | null |
音频输出数据 |
当请求音频输出时提供 了解更多 |
function_call |
object | null |
应调用的函数名称和参数 |
已弃用,推荐使用tool_calls |
tool_calls |
array | null |
模型生成的工具调用 |
如函数调用等 |
usage对象具有如下属性:
| 名称 |
类型 |
含义 |
prompt_tokens |
integer |
提示token数 |
completion_tokens |
integer |
生成token数 |
total_tokens |
integer |
总token数 |
result示例如下:
{
"id": "ed960013-eb19-43fa-b826-3c1b59657e35",
"choices": [
{
"finish_reason": "stop",
"index": 0,
"message": {
"content": "| 名次 | 国家/地区 | 金牌 | 银牌 | 铜牌 | 奖牌总数 |\n| --- | --- | --- | --- | --- | --- |\n| 1 | 中国(CHN) | 48 | 22 | 30 | 100 |\n| 2 | 美国(USA) | 36 | 39 | 37 | 112 |\n| 3 | 俄罗斯(RUS) | 24 | 13 | 23 | 60 |\n| 4 | 英国(GBR) | 19 | 13 | 19 | 51 |\n| 5 | 德国(GER) | 16 | 11 | 14 | 41 |\n| 6 | 澳大利亚(AUS) | 14 | 15 | 17 | 46 |\n| 7 | 韩国(KOR) | 13 | 11 | 8 | 32 |\n| 8 | 日本(JPN) | 9 | 8 | 8 | 25 |\n| 9 | 意大利(ITA) | 8 | 9 | 10 | 27 |\n| 10 | 法国(FRA) | 7 | 16 | 20 | 43 |\n| 11 | 荷兰(NED) | 7 | 5 | 4 | 16 |\n| 12 | 乌克兰(UKR) | 7 | 4 | 11 | 22 |\n| 13 | 肯尼亚(KEN) | 6 | 4 | 6 | 16 |\n| 14 | 西班牙(ESP) | 5 | 11 | 3 | 19 |\n| 15 | 牙买加(JAM) | 5 | 4 | 2 | 11 |\n",
"role": "assistant"
}
}
],
"created": 1745218041,
"model": "pp-docbee",
"object": "chat.completion"
}
多语言调用服务示例
Python
openai接口调用示例
import base64
from openai import OpenAI
API_BASE_URL = "http://127.0.0.1:8080"
# 初始化OpenAI客户端
client = OpenAI(
api_key='xxxxxxxxx',
base_url=f'{API_BASE_URL}'
)
#图片转base64函数
def encode_image(image_path):
with open(image_path, "rb") as image_file:
return base64.b64encode(image_file.read()).decode('utf-8')
#输入图片路径
image_path = "medal_table.png"
#原图片转base64
base64_image = encode_image(image_path)
#提交信息至PP-DocBee模型
response = client.chat.completions.create(
model="pp-docbee",#选择模型
messages=[
{
"role": "system",
"content": "You are a helpful assistant."
},
{
"role": "user",
"content":[
{
"type": "text",
"text": "识别这份表格的内容,输出html格式的内容"
},
{
"type": "image_url",
"image_url": {"url": f"data:image/jpeg;base64,{base64_image}"}
},
]
},
],
)
content = response.choices[0].message.content
print('Reply:', content)