Gradio 案例——将 dicom 文件转为 nii文件

文章目录

  • Gradio 案例——将 dicom 文件转为 nii文件
    • 界面截图
    • 依赖安装
    • 项目目录结构
    • 代码

Gradio 案例——将 dicom 文件转为 nii文件

  • 利用 SimpleITK 库,将 dicom 文件转为 nii文件
  • 更完整、丰富的示例项目见 GitHub - AlionSSS/dcm2niix-webui: The web UI for dcm2niix (DICOM to NIfTI converter)

界面截图

image.png

依赖安装

  • 新建一个虚拟环境 Python 3.9.16
  • 依赖
    • $ pip install gradio==4.29 -i "https://pypi.doubanio.com/simple/"
    • $ pip install SimpleITK==2.3.1 -i "https://pypi.doubanio.com/simple/"

项目目录结构

dicom2nii-webui       # 目录
--/lib_SimpleITK.py   # py文件
--/main.py            # py文件,入口

代码

  • lib_SimpleITK.py
import SimpleITK as sitk
import osdef dicom_to_nii(dicom_dir_path: str, nii_file_path: str):"""dicom文件转nii文件"""# 读取 dicomreader = sitk.ImageSeriesReader()img_name = reader.GetGDCMSeriesFileNames(dicom_dir_path)reader.SetFileNames(img_name)image = reader.Execute()# 转为 nii.gzimage_array = sitk.GetArrayFromImage(image)image_out = sitk.GetImageFromArray(image_array)image_out.SetOrigin(image.GetOrigin())image_out.SetSpacing(image.GetSpacing())image_out.SetDirection(image.GetDirection())# 保存nii.gz文件到配置的目录下example_nii_dir_path = os.path.dirname(nii_file_path)if not os.path.exists(example_nii_dir_path) or not os.path.isdir(example_nii_dir_path):os.mkdir(example_nii_dir_path)sitk.WriteImage(image, nii_file_path)
  • main.py
import gradio as gr
import os
import zipfile
import lib_SimpleITKexample_dicom_dir_path = 'D:/project/xxx/Task/ABC_Test_02/xxx'
example_nii_file_path = 'D:/project/res/result_image.nii.gz'def service_local_dicom_to_nii(dicom_dir_path: str, nii_file_path: str):# 校验if not dicom_dir_path or dicom_dir_path.strip() == "":gr.Warning(f"请填入[dicom文件目录路径],例如'{example_dicom_dir_path}'")returnif not nii_file_path or nii_file_path.strip() == "":nii_file_path = os.path.join(dicom_dir_path, "result_image.nii.gz")try:lib_SimpleITK.dicom_to_nii(os.path.abspath(dicom_dir_path), os.path.abspath(nii_file_path))except Exception as e:raise gr.Error("dicom 转 nii 时,发生异常:" + str(e))return nii_file_path, nii_file_path local_iface = gr.Interface(fn=service_local_dicom_to_nii,inputs=[gr.Textbox(label="dicom文件目录路径", info=f"例如'{example_dicom_dir_path}'"),gr.Textbox(label="生成的nii文件路径", info=f"例如'{example_nii_file_path}'。如果不填,会输出到dicom目录下。")],outputs=[gr.Textbox(label="生成的nii文件路径"), gr.File(label="生成的nii文件")],description="在本地电脑端启动时使用。利用 SimpleITK 库,将 dicom 文件转为 nii文件。",
)def unzip_file(zip_file_path: str, save_dir_path: str):with zipfile.ZipFile(zip_file_path, "r") as zfile:# 中文有乱码问题zfile.extractall(save_dir_path)def service_server_dicom_to_nii(file):# 解压save_dir_path = os.path.dirname(file.name)print(save_dir_path)unzip_file(file.name, save_dir_path)# dicom 转 niidicom_dir_path = save_dir_pathnii_file_path = os.path.join(save_dir_path, "result_image.nii.gz") try:lib_SimpleITK.dicom_to_nii(dicom_dir_path, nii_file_path)except Exception as e:raise gr.Error("dicom 转 nii 时,发生异常:" + str(e))# return nii_file_path, nii_file_pathreturn file.name, file.name server_iface = gr.Interface(fn=service_server_dicom_to_nii,inputs=[gr.File(label="dicom文件目录的压缩包(建议不要带中文)")],outputs=[gr.Textbox(label="生成的nii文件路径"), gr.File(label="生成的nii文件")],description="在服务器端启动时使用。利用 SimpleITK 库,将 dicom 文件转为 nii文件。",
)tabbed_interface = gr.TabbedInterface(interface_list = [local_iface, server_iface], tab_names = ["本地端", "通用端"],title="dicom 转 nii"
)
tabbed_interface.launch()

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一种请求头引起的跨域问题记录(statusCode = 400/CORS)

问题表象 问题描述 当我们需要在接口的headers中添加一个自定义的变量的时候,前端的处理是直接在拦截器或者是接口配置的地方直接进行写,比如下面的这段比较基础的写法: $http({method: "post",url:constants.backend.SERVER_LOGIN…

selenium发展史

Selenium Core 2004 年,Thoughtworks 的工程师 Jason Huggins 正在负责一个 Web 应用的测试工作,由于这个项目需要频繁回归,这导致他不得不每天做着重复且低效的工作。为了解决这个困境,Jason 开发了一个运行在 JavaScript 沙箱中…

React框架-Next 学习-1

创建一个 Next.js 应用,node版本要高,16.5以上 npm淘宝镜像切为https://registry.npmmirror.com npm config set registry https://registry.npmmirror.com npx create-next-applatest//安装后 使用npm run dev 启动 Next.js 是围绕着 页面(pages&am…

我21岁玩“撸货”,被骗1000多万

最近,撸货业界内发生了一些颇受瞩目的事件。 在郑州,数码档口下面抢手团长跑路失联,涉及金额几百万,在南京,一家知名的电商平台下的收货站点突然失联,涉及金额高达一千多万,令众多交易者震惊不已…

回归预测 | Matlab实现GA-LSSVM遗传算法优化最小二乘支持向量机多输入单输出回归预测

回归预测 | Matlab实现GA-LSSVM遗传算法优化最小二乘支持向量机多输入单输出回归预测 目录 回归预测 | Matlab实现GA-LSSVM遗传算法优化最小二乘支持向量机多输入单输出回归预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 Matlab实现GA-LSSVM遗传算法优化最小…

基于 Spring Boot 博客系统开发(十)

基于 Spring Boot 博客系统开发(十) 本系统是简易的个人博客系统开发,为了更加熟练地掌握 SprIng Boot 框架及相关技术的使用。🌿🌿🌿 基于 Spring Boot 博客系统开发(九)&#x1f…

【考研数学】张宇《1000题》强化阶段正确率多少算合格?

张宇1000题真的很练人心态.... 基础不好,建议别碰1000题 基础好,1000题建议在两个月以内刷完 如果自己本身在基础阶段学的比较水,自己的薄弱点刷了一小部分题没有针对性完全解决,转身去刷1000题就会发现,会的题目刷…

算术平均数

算术平均数(average)是一组数据相加后除以数据的个数而得到的结果,是度量数据水平的常用统计量,在参数估计和假设检验中经常用到。比如:用职工平均工资来衡量职工工资的一般水平,用平均体重来观察某一人群体…

通信指挥类装备(多链路聚合设备)-应急通信指挥解决方案

现场通信指挥系统是一种功能全面的便携式音视频融合指挥通信平台,可实现现场应急救援指挥、多种通信手段融合、现场通信组网等功能,是现场指挥系统的延伸。 多链路聚合设备,是一款通信指挥类装备,具有 4G/5G,专网&…

YOLOv8训练流程-原理解析[目标检测理论篇]

关于YOLOv8的主干网络在YOLOv8网络结构介绍-CSDN博客介绍了,为了更好地学习本章内容,建议先去看预测流程的原理分析YOLOv8原理解析[目标检测理论篇]-CSDN博客,再次把YOLOv8网络结构图放在这里,方便随时查看。 ​ 1.前言 YOLOv8训练…

《ESP8266通信指南》17-结尾篇(完结撒花)

《ESP8266通信指南》16-MQTT收发通信-完整代码-(Lua烧录代码的深度思考与串口拦截)-CSDN博客 《ESP8266通信指南》系列的第十六篇,专注于MQTT收发通信的完整代码以及深度思考与串口拦截。本小节首先列出了往期内容,然后提出了本节…

哈希表的理解和实现

目录 1. 哈希的概念 (是什么) 2. 实现哈希的两种方式 (哈希函数) 2.1. 直接定址法 2.2. 除留余数法 2.2.1. 哈希冲突 3. 补充知识 3.1. 负载因子 3.2. 线性探测和二次探测 4. 闭散列实现哈希表 (开放定址法) 4.1. 开放定址法的实现框架 4.2. Xq::hash_table::insert…

今天遇到一个GPT解决不了的问题

问题描述 你好,postman的一个post请求,编辑器里面放了一个很长的json数据,报Tokenization is skipped for long lines for performance reasons. This can be configured via editor.maxTokenizationLineLength.,但是同样的数据&a…

家用充电桩远程监控安全管理系统解决方案

家用充电桩远程监控安全管理系统解决方案 在当今电动汽车日益普及的背景下,家用充电桩的安全管理成为了广大车主关注的重点问题。为了实现对充电桩的高效、精准、远程监控,一套完善的家用充电桩远程监控安全管理系统解决方案应运而生。本方案旨在通过先…

AI 绘画神器 Fooocus 图生图:图像放大或变化、图像提示、图像重绘或扩充、反推提示词、生成参数提取、所需模型下载

本文收录于《AI绘画从入门到精通》专栏,专栏总目录:点这里,订阅后可阅读专栏内所有文章。 大家好,我是水滴~~ 本文讲述 Fooocus 的图生图功能,主要内容包括:图像放大或变化、图像提示、图像重绘或扩充、反推…

深入理解MySQL三大日志:redo log、binlog、undo log

前言 MySQL是一个功能强大的关系型数据库管理系统,它的高可靠性、高性能和易用性使得它成为众多企业和开发者的首选。在MySQL内部,为了保证数据的完整性、恢复能力和并发性能,设计了一套复杂的日志系统。其中,redo log、bin log和…

Qt+C++串口调试工具

程序示例精选 QtC串口调试工具 如需安装运行环境或远程调试,见文章底部个人QQ名片,由专业技术人员远程协助! 前言 这篇博客针对《QtC串口调试工具》编写代码,代码整洁,规则,易读。 学习与应用推荐首选。 …

Mybatis基础操作-删除

Mybatis基础操作-删除 删除 package com.itheima.mapper;import org.apache.ibatis.annotations.Delete; import org.apache.ibatis.annotations.Mapper;Mapper //在运行时,会自动生成该接口的实现类对象(代理对象),并且将该对象…

Vue3知识总结-4

Vue3知识总结-4 文章目录 Vue3知识总结-4插槽Slots渲染作用域默认内容具名插槽插槽中的数据传递具名插槽传递数据 组件声明周期声明周期示意图 组件生命周期的应用动态组件组件保持存活组件被卸载 异步组件依赖注入 插槽Slots 在某些场景中,可能想要为子组件传递一…

redis中的集群模式

主从复制、主从同步(解决高并发读的问题) 主从同步原理: 1.全量同步 slave(从节点)每次请求数据同步会带两个参数:replid和offset。 replid:第一次请求同步时,replid和master的replid不一样,这…