没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:龚雪|2024-05-23 10:31:03.290|阅读 13 次
概述:本文主要介绍如何用OpenAI模型增强Office文档(Word和Excel)的可访问性,欢迎下载最新版组件体验!
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
DevExpress Office File API是一个专为C#, VB.NET 和 ASP.NET等开发人员提供的非可视化.NET库。有了这个库,不用安装Microsoft Office,就可以完全自动处理Excel、Word等文档。开发人员使用一个非常易于操作的API就可以生成XLS, XLSx, DOC, DOCx, RTF, CSV 和 Snap Report等企业级文件。
出于与可访问性相关的原因,某些业务使用场景要求Office文档为图形内容(图像、图表等)包含有意义的描述/替代文本(Alt text)。Alt Text帮助有视觉障碍的人理解图片和其他图形内容(屏幕阅读器不能正确阅读没有Alt Text的包含图像的文档)。此外,没有Alt Text的文档不能正确导出为可访问的PDF(这些PDF无法通过可访问性验证)。
OpenAI平台提供了解决这一特殊需求/问题的解决方案(OpenAI的生成式AI可以帮助描述Word和Excel文件中的图像和其他图形内容)。在这本文中,我们将向您展示如何将OpenAI模型集成到DevExpress驱动的Office File API应用程序中,并添加缺失的媒体描述和Alt Text。处理完文档后,用户可以将文件导出为可访问的PDF,或者在文档查看器中上传,然后使用屏幕阅读器阅读。
DevExpress Office File API 最新正式版下载
DevExpress技术交流群10:532598169 欢迎一起进群讨论
我们创建了一个示例项目来帮助说明策略,这个REST API应用程序包括两个端点:描述Word文档中的图像和Excel文件中的图表。
您可以从GitHub下载这个项目:
在您将此解决方案纳入应用程序之前,请务必阅读并理解OpenAI的许可协议和使用条款。
首先,在项目中添加对包的引用,这个包适应OpenAI的REST APIs,因此它们可以在非Azure OpenAI开发中使用。
我们将使用这个API发送请求和处理响应。
下面的代码片段发送一个请求来描述一个图像,并获得一个带有响应的字符串。
class OpenAIClientImageHelper { OpenAIClient client; internal OpenAIClientImageHelper(string openAIApiKey) { client = new OpenAIClient(openAIApiKey, new OpenAIClientOptions()); } string ConvertDXImageToBase64String(DXImage image) { using (MemoryStream stream = new MemoryStream()) { image.Save(stream, DXImageFormat.Png); byte[] imageBytes = stream.ToArray(); return Convert.ToBase64String(imageBytes); } } internal async Task<string> DescribeImageAsync(OfficeImage image) { string base64Content = ConvertDXImageToBase64String(image.DXImage); string imageContentType = OfficeImage.GetContentType(OfficeImageFormat.Png); return await GetImageDescription($"data:{imageContentType};base64,{base64Content}"); } internal async Task<string> GetImageDescription(string uriString) { ChatCompletionsOptions chatCompletionsOptions = new() { DeploymentName = "gpt-4-vision-preview", Messages = { new ChatRequestSystemMessage("You are a helpful assistant that describes images."), new ChatRequestUserMessage( new ChatMessageTextContentItem("Give a description of this image in no more than 10 words"), new ChatMessageImageContentItem(new Uri(uriString))), }, MaxTokens = 300 }; Response<ChatCompletions> chatResponse = await client.GetChatCompletionsAsync(chatCompletionsOptions); ChatChoice choice = chatResponse.Value.Choices[0]; return choice.Message.Content; } }
我们可以在DevExpress支持的Word Processing Document API应用程序中使用上面描述的API,使用集合检索文档图像。按类型对检索到的形状排序,并检查图像是否包含Alt Text,然后调用上面实现的OpenAIClientImageHelper.GetImageDescription方法来生成图像描述。
public async Task<IActionResult> GenerateImageAltText(IFormFile documentWithImage, [FromQuery] RichEditFormat outputFormat) { try { var imageHelper = new OpenAIClientImageHelper(openAIApiKey); using (var server = new RichEditDocumentServer()) { await RichEditHelper.LoadFile(server, documentWithImage); server.GenerateAltTextForImages((document) => { foreach (var shape in document.Shapes) { if (shape.Type == DevExpress.XtraRichEdit.API.Native.ShapeType.Picture && string.IsNullOrEmpty(shape.AltText)) shape.AltText = imageHelper.DescribeImageAsync(shape.PictureFormat.Picture).Result; } }); Stream result = RichEditHelper.SaveDocument(server, outputFormat); string contentType = RichEditHelper.GetContentType(outputFormat); return File(result, contentType, $"result.{outputFormat}"); } } catch (Exception e) { return StatusCode(500, e.Message + Environment.NewLine + e.StackTrace); } }
您还可以为Excel图表生成Alt Text,我们的项目展示了如何结合Azure OpenAI和Spreadsheet Document APIs来解决这个特殊的需求。
首先,您需要将Excel图表转换为图像,调用方法从每个图表中获取OfficeImage对象,然后调用上面实现的OpenAIClientImageHelper.GetImageDescription方法来生成图像描述并将其用作Alt Text。
public async Task<IActionResult> GenerateChartAltText(IFormFile documentWithImage, [FromQuery] SpreadsheetFormat outputFormat) { try { var imageHelper = new OpenAIClientImageHelper(openAIApiKey); using (var workbook = new Workbook()) { await SpreadsheetHelper.LoadWorkbook(workbook, documentWithImage); foreach (var worksheet in workbook.Worksheets) { foreach (var chart in worksheet.Charts) { OfficeImage image = chart.ExportToImage(); chart.AlternativeText = await imageHelper.DescribeImageAsync(image); } } Stream result = SpreadsheetHelper.SaveDocument(workbook, outputFormat); string contentType = SpreadsheetHelper.GetContentType(outputFormat); return File(result, contentType, $"result.{outputFormat}"); } } catch (Exception e) { return StatusCode(500, e.Message + Environment.NewLine + e.StackTrace); } }
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@wqylolg.cn
文章转载自:慧都网可视化项目时间线对于有效规划和跟踪至关重要。在本篇博文中,您将学习如何使用 C# 在 Excel 中创建甘特图。只需几行代码,即可自动生成动态、美观的甘特图。
本文将为大家介绍DevExpress XAF如何将.NET Aspire集成到Blazor项目中,欢迎下载最新版组件体验!
在线协同文档编辑器ONLYOFFICE现已支持阿里通义千问( Qwen),带来先进的 AI 功能,实现更智能的文档编辑。本指南将向您展示如何将 Qwen 连接到 ONLYOFFICE,并充分利用其功能。
需要从 PDF 文档中删除特定页面?本快速指南将向您展示如何仅用几行代码删除不需要的页面。
无需安装Office,自动化编辑、快照、压缩Excel,Word等多种文档,还可生成多种条形码
DevExpress DXperience Subscription高性价比的企业级.NET用户界面套包,助力企业创建卓越应用!
DevExpress Universal Subscription优秀的界面控件开发包,帮助企业构建卓越应用!
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@wqylolg.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢