File2MD:123种文件格式统一转换微服务,助力AI应用开发与知识库构建

news2026/5/5 16:21:39
1. 项目概述与核心价值最近在折腾一个挺有意思的项目叫 File2MD。简单来说它是一个能把123 种不同格式的文件——从常见的 Word、PDF、PPT、Excel到图片、音频、视频甚至包括苹果的 iWork 套件Keynote, Pages, Numbers和 82 种编程语言的源代码文件——统统转换成统一的、对大型语言模型LLM友好的 Markdown 代码块格式的微服务。听起来是不是有点像“文件格式的万能翻译器”没错它的核心价值就在于此。在 AI 应用开发、知识库构建、文档自动化处理这些场景里我们经常遇到一个头疼的问题数据源五花八门格式千奇百怪。你想让一个 AI 模型去理解一份复杂的 PDF 报告或者从一堆产品设计图里提取关键信息第一步往往不是模型推理而是繁琐的“数据清洗”和“格式转换”。File2MD 就是为了解决这个“第一步”而生的。它通过一个统一的 API 接口把各种非结构化的文件内容转换成结构清晰、易于解析的 Markdown 文本让你能更专注于业务逻辑而不是和文件解析库较劲。我最初接触这个项目是因为需要处理一个混合了技术文档Word、数据报表Excel、设计稿PNG和会议录音MP3的内部知识库。手动处理这些文件不仅耗时而且一致性难以保证。File2MD 的出现让我可以用一套代码、一个接口批量搞定所有格式处理效率提升了不止一个量级。接下来我就结合自己的实际部署和使用经验把这个项目的设计思路、核心功能、避坑指南以及扩展玩法给大家掰开揉碎了讲清楚。2. 架构设计与核心组件解析File2MD 的整体架构非常清晰采用了典型的微服务设计模式核心是围绕“解析器Parser”和“异步任务队列”这两个概念构建的。理解了这个架构你就能明白它为什么能如此灵活地支持上百种格式。2.1 核心架构解析器工厂模式项目最巧妙的设计在于它的解析器系统。它没有用一个庞大的、臃肿的“万能解析函数”而是采用了工厂模式。在app/parsers/目录下你会看到 16 个独立的解析器模块比如pdf.py,docx.py,image.py,audio.py等。每个解析器都继承自一个统一的BaseParser基类只需要实现两个核心方法get_supported_extensions()告诉系统我能处理哪些后缀的文件和parse()具体的解析逻辑。这种设计的好处显而易见高内聚低耦合每个解析器只关心自己负责的格式代码逻辑独立维护和升级非常方便。比如要优化 PDF 的解析精度你只需要改pdf.py完全不会影响到处理 Word 文档的模块。易于扩展如果你想增加对一种新格式比如.epub电子书的支持只需要新建一个epub.py实现上述两个方法然后在解析器注册表里挂载上去就行整个系统的其他部分完全不用动。动态加载系统启动时会自动扫描并注册所有解析器。这意味着你可以热插拔解析器模块甚至可以根据不同部署环境比如轻量版、全功能版来动态加载不同的解析器集合。2.2 异步处理与队列管理处理文件尤其是大文件或包含多媒体的文件如 PDF 内嵌大量图片、长音频是典型的 I/O 密集型或计算密集型任务。如果采用同步阻塞的方式一个耗时 10 秒的 PDF 转换请求就会卡住整个 API导致其他快速请求如转换一个 TXT 文件也无法响应。File2MD 用 FastAPI 的异步特性完美解决了这个问题。对于单个文件的同步转换/v1/convert它使用async/await避免阻塞。而对于批量任务/v1/convert-batch它引入了异步任务队列模式。任务提交客户端提交一批文件后API 会立即为每个文件生成一个唯一的task_id并返回告知用户“任务已接收正在排队”而不是“正在处理”。这保证了 API 的快速响应。后台处理任务被放入一个由 Redis 支持的队列中。一个或多个后台工作进程Worker会从队列中取出任务调用对应的解析器进行实际处理。处理进度和结果会被写回 Redis。结果查询客户端可以通过task_id随时查询任务状态/v1/task/{task_id}或查看整体队列情况/v1/queue/info。这个设计让系统具备了良好的弹性和可观测性。你可以通过调整MAX_CONCURRENT环境变量来控制同时处理的任务数防止服务器过载。同时所有任务状态可查即使某个任务失败也不会影响队列中的其他任务。2.3 关键技术栈选型与考量为什么是 FastAPI PaddleOCR Docker 这个组合这里面的选型充满了实战的考量。FastAPI作为 Python 领域性能第一梯队的异步 Web 框架它天生适合处理 File2MD 这种高 I/O 并发的场景。其基于 Pydantic 的自动请求/响应验证、自动生成的交互式 API 文档Swagger UI极大地提升了开发效率和接口的健壮性。对于需要频繁处理上传、下载的微服务FastAPI 的异步文件处理能力是关键。PaddleOCR这是项目从 Tesseract 切换到 PaddleOCR 的一个重要决策。PaddleOCR 由百度开源在中文场景下的识别准确率尤其是对复杂版面、手写体、多语种混合的识别显著优于 Tesseract。它提供了丰富的预训练模型并且支持通过 Python 包直接安装部署成本低。对于 File2MD 的目标场景处理各类含文字的图片、扫描件这个选择非常务实。Docker支持 123 种格式意味着依赖库极其复杂。从 LibreOffice 套件处理 .doc, .ppt 等旧格式、Poppler处理 PDF、到 ImageMagick处理 SVG 转换、FFmpeg处理音视频手动在每台服务器上配置这些依赖无异于一场噩梦。Docker 化将所有这些依赖连同正确的系统环境一起打包实现了“一次构建处处运行”。docker-compose进一步将 API 服务、Redis 缓存、Nginx 反向代理编排在一起让生产级部署变得像运行一个脚本那么简单。3. 核心功能深度解析与实操要点File2MD 的功能远不止“把文件变成文本”。它对不同格式的文件进行了智能化的深度处理输出的 Markdown 是高度结构化和富含语义信息的。3.1 文档类文件的智能解析对于 Word、PDF 这类文档解析器做的不仅仅是提取文字。保留结构信息它会识别并保留文档的标题层级H1, H2, H3、列表有序、无序、表格等。一个复杂的 Word 表格会被转换成 Markdown 的表格语法而不仅仅是平铺的文字。并发图片处理核心优化点这是 2.6.0 版本的一个重大性能优化。传统的解析流程是解析文档 - 提取出一张图片 - 调用 OCR 识别 - 等待返回 - 提取下一张图片... 串行处理耗时与图片数量成正比。File2MD 引入了并发图片处理。当解析器如PdfParser,DocxParser提取出文档中的所有图片后它会使用asyncio.gather()同时发起所有图片的 OCR 识别和 AI 视觉分析请求。实测下来对于一个包含 20 张截图的 PDF 技术文档处理速度从原来的近 2 分钟缩短到了 20 秒左右提升近6 倍。这个功能可以通过MAX_IMAGES_PER_DOC环境变量控制并发数量设为-1则不限制。输出格式统一无论输入是 .docx 还是 .pdf最终输出都会包裹在document 代码块中。这为下游的 LLM 处理提供了极其一致的接口。LLM 看到document 就知道“哦这是一份文档里面可能包含标题、段落、表格和图片描述。”实操心得在处理含有大量高清图片的 PDF 时建议适当调低MAX_IMAGES_PER_DOC比如设为 10或者确保你的 Vision API如 GPT-4V有较高的并发配额。否则瞬间发起大量图片识别请求可能会导致 API 限流。3.2 图像与 SVG 文件的“双重理解”对图片的处理体现了项目的“AI 原生”思维。它不仅仅是 OCR。OCR 文字提取首先使用 PaddleOCR 精准识别图片中的所有文字包括其位置信息。AI 视觉特征描述然后可选择性地调用 Vision API如 GPT-4o-mini让 AI 模型描述图片的视觉内容、图表类型、情感色彩等。例如一张折线图OCR 可能只能读出坐标轴上的数字标签而 Vision API 会总结出“这是一张展示过去一年用户增长趋势的折线图Q4 增长显著”。SVG 的特殊处理SVG 既是代码文件XML也是图像。File2MD 的SvgParser会做两件事一是将其源码作为代码块保留二是将其转换为 PNG 格式然后走上述“OCR Vision”的流程获取其视觉描述。最终输出会同时包含# Code和# Visual_Features两部分。// 一个 SVG 文件的转换结果示例 { content: svg\n# Code\nsvg.../svg\n\n# Visual_Features: A minimalist logo of a leaf inside a circle, using a gradient green color, conveying an eco-friendly and modern brand image.\n }3.3 音视频文件的转录与结构化音视频处理是 2.4.0 版本加入的杀手级功能。它不仅仅是调用一个语音转文字ASRAPI。智能预处理管道标准化无论输入是 MP3 还是 WAV都会先统一转换为 16kHz、单声道的 WAV 格式这是大多数 ASR 模型的最佳输入格式。降噪应用一个 80Hz 的高通滤波器有效过滤掉空调、电流声等低频环境噪音。语音活动检测VAD这不是简单的静音检测。它会计算音频信号的 RMS均方根能量并采用一种自适应阈值算法以能量排序后第 10 百分位的值作为基线再加 3dB 作为触发阈值。这种方法能很好地适应不同录音环境安静的会议室 vs. 嘈杂的咖啡馆。智能分段检测到静音超过 300ms 则认为是一段话的结束。但还会对过短的片段进行合并避免把一句话拆得支离破碎影响 ASR 上下文理解。并发 ASR 转换预处理后得到的多个音频片段会被并发地提交给 ASR 服务如 OpenAI Whisper。这比把整个音频文件扔给 ASR 然后等它一次性处理完要快得多特别是对于长音频速度提升3-5 倍很常见。视频处理视频文件会先通过 FFmpeg 提取音轨然后走上述音频处理流程。最终输出不仅包含转录文本还会生成标准的SRT 字幕格式每一行都带有精确的时间戳HH:MM:SS,mmm方便后续做视频摘要或关键片段定位。避坑指南音频处理对ffmpeg的版本和编解码器支持比较敏感。在 Docker 部署中已经妥善解决。如果你在本地开发环境遇到“无法解码 xxx 格式”的错误通常是系统缺少对应的ffmpeg编解码器库需要根据系统Ubuntu/macOS安装完整的ffmpeg而非最小化版本。3.4 代码文件的语法高亮保留对于 82 种编程语言文件CodeParser的核心任务是“无损转换”。它利用python-magic或文件扩展名准确判断语言类型然后将原始代码放入对应的 Markdown 代码块中例如python,javascript。这保留了代码的原始格式和缩进下游的 LLM 可以完美地对其进行语法分析、解释或重构。这对于代码知识库、自动化代码评审等场景至关重要。4. 全链路部署与配置实战理论讲完了我们动手把它跑起来。File2MD 提供了多种部署方式这里我强烈推荐Docker Compose 方案这也是最接近生产环境、最能避免依赖地狱的方式。4.1 Docker Compose 一键部署推荐项目根目录下的docker-deploy.sh脚本是个宝藏它把最佳实践都封装好了。# 1. 克隆项目 git clone https://github.com/MedicNex/file2md.git cd file2md # 2. 一键部署这个脚本会做很多事 ./docker-deploy.sh运行这个脚本后它会依次执行以下操作你只需要看着就行环境检查确保 Docker 和 Docker Compose 已安装。安全配置生成自动生成一个强随机的API_KEY用于接口认证。自动生成一个强随机的REDIS_PASSWORD。如果目录下没有.env文件它会基于.env.example创建一份并填入刚才生成的密钥。这一点非常贴心避免了手动设置弱密码的安全隐患。构建与启动执行docker-compose up -d拉起三个服务file2md-api: 主 API 服务。redis: 缓存和队列服务。nginx: 反向代理服务可选但推荐用于生产环境提供负载均衡和 SSL 终端。健康检查脚本会等待服务启动然后调用/v1/health接口确认服务状态。信息输出最后脚本会打印出访问地址和生成的 API Key。部署完成后你可以访问http://你的服务器IP:8999/docs完整的交互式 API 文档Swagger UI在这里可以直接测试接口。http://你的服务器IP:8999/webui内置的 Web 管理界面Beta可以上传文件、管理 API Key、查看任务。http://你的服务器IP:8999/v1/health健康检查端点。管理命令也非常简单# 查看服务状态 ./docker-deploy.sh status # 查看实时日志排错神器 ./docker-deploy.sh logs # 重启服务 ./docker-deploy.sh restart # 停止服务 ./docker-deploy.sh stop4.2 关键环境变量详解虽然一键部署脚本帮你生成了配置但理解核心配置项对于调优和排查问题很重要。你需要关注.env文件里的这些变量# 认证相关必须 API_KEYyour-generated-key-here # 多个Key用逗号分隔 # 例如API_KEYkey-for-app1,key-for-internal,key-for-backup # 图像AI描述功能可选但建议配置 VISION_API_KEYsk-xxx # 你的OpenAI API Key或其他兼容API的Key VISION_API_BASEhttps://api.openai.com/v1 # 可替换为其他兼容端点 VISION_MODELgpt-4o-mini # 模型名称平衡速度与成本 # 音频转录功能可选需要时配置 ASR_API_KEYsk-yyy # 用于语音识别的API Key ASR_API_BASEhttps://api.openai.com/v1 ASR_MODELwhisper-1 # 性能与资源控制 MAX_CONCURRENT5 # 全局最大并发任务数根据服务器CPU核心数调整 MAX_IMAGES_PER_DOC5 # 单个文档内图片的最大并发处理数-1表示无限制 MAX_FILE_SIZE100 # 单个文件最大大小MB # 服务端口 PORT8999配置心得MAX_CONCURRENT不宜设置过高尤其是当任务涉及调用外部 API如 Vision/ASR时。过高的并发会导致外部 API 限流反而降低整体吞吐量。建议从 CPU 核心数的 1-2 倍开始测试。如果主要处理本地文件如纯文本、代码、不含图片的PDF可以暂时不配置VISION_API_KEY和ASR_API_KEY系统会跳过相应步骤仅进行基础解析和 OCR。MAX_IMAGES_PER_DOC是控制“并发图片处理”的关键。如果处理大量含图的 PDF 时遇到 Vision API 报错429 Too Many Requests应首先调低这个值。4.3 本地开发环境搭建macOS 避坑指南如果你需要在 macOS 上做二次开发不推荐直接用 Docker Desktop资源消耗大文件系统性能有损耗。可以按以下步骤搭建本地环境我踩过的坑都标出来了。# 1. 创建虚拟环境隔离依赖 python -m venv venv source venv/bin/activate # 2. 【关键步骤】按顺序安装核心依赖避免版本冲突 pip install --upgrade pip setuptools wheel # 先安装框架和基础库 pip install fastapi uvicorn pydantic python-multipart starlette loguru python-dotenv # 【大坑预警】PaddleOCR 和 PaddlePaddle 必须安装指定版本否则可能报“Unknown argument: use_gpu” pip install paddlepaddle2.5.2 # 必须 2.5.2 pip install paddleocr2.7.0.3 # 必须 2.7.0.3 # 最后安装项目其他依赖 pip install -r requirements.txt # 3. 安装系统依赖 brew install imagemagick # 用于SVG转PNG brew install ffmpeg # 用于音视频处理 # 注意PaddleOCR 在 macOS 上是纯 Python 实现无需额外系统库但首次运行会下载约 1GB 模型文件。 # 4. 配置环境变量 echo DEBUGtrue PORT8999 API_KEYdev-local-test-key REDIS_CACHE_ENABLEDfalse .env # 5. 启动服务 python -m uvicorn app.main:app --host 0.0.0.0 --port 8999 --reload首次启动时控制台会显示 PaddleOCR 正在下载模型det,rec,cls需要保持网络通畅。下载完成后模型会缓存在用户目录下下次启动就快了。5. API 使用详解与集成示例服务跑起来后我们来看看怎么用它。API 设计得很 RESTful主要端点就几个但功能强大。5.1 同步单文件转换这是最常用的接口适合即时性的、文件不大的转换需求。curl -X POST http://localhost:8999/v1/convert \ -H Authorization: Bearer your-api-key \ -F file/path/to/your/document.pdf关键点Authorization头是必须的格式为Bearer 你的API_KEY。使用-F参数以multipart/form-data格式上传文件。响应是同步的会一直等待文件处理完成才返回。所以对于大文件或处理慢的格式如图片多的PDF建议使用下面的异步批量接口。响应示例分析{ filename: 季度报告.pdf, size: 2048576, content_type: application/pdf, content: document\n# 2024年第一季度业务报告\n\n## 1. 业绩概览\n...\n\n## 2. 市场分析\n...\n\n![Figure 1: 用户增长趋势图](描述这是一张柱状图展示了...)\n, duration_ms: 3250 }duration_ms字段非常有用可以帮你监控不同文件类型的处理性能。content字段就是转换后的 Markdown 内容直接可以喂给 LLM 或存入向量数据库。5.2 异步批量文件转换这是处理大量文件或大文件的核心接口。它不会阻塞而是返回任务 ID。curl -X POST http://localhost:8999/v1/convert-batch \ -H Authorization: Bearer your-api-key \ -F filesreport1.docx \ -F filesscreenshot.png \ -F filesmeeting.mp3响应{ submitted_tasks: [ { task_id: 550e8400-e29b-41d4-a716-446655440000, message: Task submitted to conversion queue, filename: report1.docx, status: pending }, // ... 其他文件任务 ], total_count: 3, success_count: 3, failed_count: 0 }拿到task_id后你可以轮询查询任务状态curl -X GET http://localhost:8999/v1/task/550e8400-e29b-41d4-a716-446655440000 \ -H Authorization: Bearer your-api-key当状态变为completed时响应中会包含转换结果如果为failed则会包含错误信息。5.3 纯 OCR 识别接口如果你只需要图片中的文字不需要 AI 视觉描述或者想节省 Vision API 的调用成本可以使用专用的 OCR 接口。curl -X POST http://localhost:8999/v1/ocr \ -H Authorization: Bearer your-api-key \ -F fileinvoice.jpg这个接口只使用 PaddleOCR 进行识别响应更快且不消耗 Vision API 额度。返回的ocr_text字段就是纯文本结果。5.4 前端集成示例在实际项目中我们通常会在前端上传文件并调用这个 API。这里是一个使用 JavaScript Fetch API 的简单示例async function convertFile(file) { const formData new FormData(); formData.append(file, file); const response await fetch(http://your-file2md-server/v1/convert, { method: POST, headers: { Authorization: Bearer YOUR_API_KEY }, body: formData }); if (!response.ok) { throw new Error(转换失败: ${response.status}); } const result await response.json(); // result.content 就是转换后的Markdown console.log(转换结果:, result.content); return result.content; } // 监听文件上传输入框的变化 document.getElementById(fileInput).addEventListener(change, async (event) { const file event.target.files[0]; if (file) { try { const markdown await convertFile(file); // 将 markdown 显示在页面上或发送到后端 document.getElementById(output).textContent markdown; } catch (error) { console.error(Error:, error); alert(文件转换失败请检查控制台。); } } });对于批量上传你可以使用类似的逻辑但调用/v1/convert-batch接口并实现一个轮询机制来检查每个task_id的状态。6. 常见问题排查与性能调优在实际使用中你可能会遇到一些问题。下面是我总结的一些常见情况及解决方法。6.1 部署与启动问题问题现象可能原因解决方案Docker 启动失败提示端口冲突端口 8999 已被占用修改docker-compose.yml或.env中的PORT变量或停止占用端口的进程。首次启动时 PaddleOCR 下载模型极慢或失败网络连接问题特别是国内访问 GitHub 或 PaddlePaddle 源慢1. 使用 Docker 部署镜像已内置模型无需下载。2. 本地开发可尝试设置代理或使用国内镜像源需修改 PaddleOCR 源码中的模型下载地址。调用接口返回401 UnauthorizedAPI Key 未设置或错误1. 检查.env文件中的API_KEY是否正确设置。2. 检查请求头Authorization: Bearer key格式是否正确key 前后有无多余空格。处理 PDF 或图片时内存溢出OOM文件过大或MAX_IMAGES_PER_DOC设置过高导致并发处理过多图片1. 增加 Docker 容器的内存限制在docker-compose.yml中设置mem_limit。2. 调低MAX_IMAGES_PER_DOC。3. 对于超大的 PDF考虑在业务层先进行分页处理。音频/视频处理失败报 FFmpeg 错误系统缺少必要的音视频编解码库确保已安装完整版的ffmpeg。在 Ubuntu 上可以sudo apt install ffmpeg libavcodec-extra在 macOS 上brew install ffmpeg。6.2 转换结果相关问题问题现象可能原因解决方案/优化建议中文 PDF 识别乱码或精度低PDF 中的文字是图片而非文本或字体嵌入异常1. 确保已使用 PaddleOCR项目默认其中文识别能力强于 Tesseract。2. 对于扫描版 PDF可以尝试在上传前用专业的 OCR 软件预处理。3. 检查 PDF 本身质量低分辨率图片必然影响识别率。图片的 AI 视觉描述不准确或为空Vision API如 GPT-4V调用失败或返回空1. 检查.env中VISION_API_KEY和VISION_API_BASE是否正确且 API Key 有余额和权限。2. 网络问题导致请求超时可适当增加超时设置需修改代码。3. 某些抽象、复杂的图片 AI 可能无法描述这是模型本身限制。音频转录时间戳不准音频背景噪音大或语音活动检测VAD参数不匹配当前环境1. 尝试在业务端先对音频进行降噪预处理。2. 可以微调app/parsers/audio.py中的 VAD 参数如silence_threshold_db静默阈值和min_silence_len最小静默长度。处理速度慢特别是批量任务外部 APIVision/ASR调用是瓶颈或服务器资源不足1.最重要的调优合理设置MAX_CONCURRENT。不要超过你的外部 API 的速率限制。2. 对于纯文本/代码文件速度很快瓶颈主要在含图、音视频的文件。3. 考虑使用 Redis 缓存项目已支持缓存频繁处理的相同文件 hash 的结果。6.3 性能调优实战建议分级处理策略在你的业务逻辑中可以根据文件类型采取不同策略。例如纯文本文件走同步接口即时返回大型 PDF 或音视频走异步接口并引导用户稍后查看结果。缓存策略对于经常被重复转换的公共文件如公司制度 PDF可以在调用 File2MD 之前先用自己的缓存系统如 Redis根据文件哈希值查找是否有现成的 Markdown 结果。File2MD 内部也支持 Redis 缓存确保在.env中正确配置REDIS_URL即可启用。队列监控定期调用/v1/queue/info接口监控pending_count和processing_count。如果pending_count持续增长说明任务产生速度大于消费速度需要考虑增加后端 Worker横向扩展或优化单个任务处理速度。资源隔离在生产环境可以考虑将 CPU/内存密集型的解析器如 PDF、音视频与轻量级解析器如文本、代码部署到不同规格的服务器上并通过队列进行任务路由实现资源的最佳利用。这个项目本质上是一个强大的“文件理解”中间件。它把杂乱无章的文件世界整理成了 LLM 能轻松消化的结构化文本。无论是构建企业知识库、开发智能客服、还是做内容分析它都能帮你省下大量前期数据处理的精力。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2585506.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…