在糖尿病患者信息管理系统中,导入病人信息功能!

2024-09-08 03:48

本文主要是介绍在糖尿病患者信息管理系统中,导入病人信息功能!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在糖尿病患者信息管理系统中,导入病人信息功能!form表单提交数据(Excel文件),在后台得不到file文件,解决方法:

        private File filePath; //文件
        private String fileName; //文件名
        private String fileType; //文件类型

注:上面filePath必须有,否则下面得到filePath为空!

/**
* 导入病人信息,并且插入用户信息
*/
public String importPatient() throws Exception {
if (filePath != null) {
FileInputStream fis = new FileInputStream(filePath);
Workbook readWb = Workbook.getWorkbook(fis);
// 得到sheet
Sheet readSheet = readWb.getSheet(0);
// 得到多少列
int rsColumns = readSheet.getColumns();
// 得到多少行
int rsRows = readSheet.getRows();
// 单元格
Cell cell;
// 实例化病人对象
Patient patient = new Patient();
SysUser sysUser = new SysUser();
Map<Integer, String> map = new HashMap<Integer, String>();
for (int i = 1; i < rsRows; i++) {
for (int j = 0; j < rsColumns; j++) {
cell = readSheet.getCell(j, i);
map.put(j, cell.getContents());
}
UUID uuid = UUID.randomUUID();
String patientId = uuid.toString();
patient.setId(patientId);
//用户信息
sysUser.setId(uuid.toString());
sysUser.setUserName(map.get(5));
sysUser.setPassword(md5keyBean.getkeyBeanofStr("123456"));
sysUser.setNickName(map.get(1));
sysUser.setPhone(map.get(5));
//1:默认不锁定;0:锁定
sysUser.setStatus("1");
//角色id
List<SysRole> sysRoles = sysRoleService.findAllSysRoles();
if(sysRoles.size()>0) {
for (int j = 0; j < sysRoles.size(); j++) {
if("病人".equals(sysRoles.get(j).getName())) {
sysUser.setSysRole(sysRoles.get(j));
}
}
}
//病人id
sysUser.setFlagId(patientId);
sysUser.setCreateTime(new Date());
sysUserService.saveSysUser(sysUser);
patient.setNumber(map.get(0));
patient.setRealName(map.get(1));
patient.setAge(Integer.parseInt(map.get(2)));
// 性别:1男0女
if ("男".equals(map.get(3))) {
patient.setSex("1");
} else if ("女".equals(map.get(3))) {
patient.setSex("0");
} else {
patient.setSex("1");
}
patient.setNation(map.get(4));
patient.setPhone(map.get(5));
// 婚况:1:已婚 0:未婚
if ("已婚".equals(map.get(6))) {
patient.setStateMarriage("1");
} else if ("未婚".equals(map.get(6))) {
patient.setStateMarriage("0");
} else {
patient.setStateMarriage("1");
}
patient.setBirthAdress(map.get(7));
patient.setAddress(map.get(8));
patient.setOrganize(map.get(9));
patient.setNumberId(map.get(10));
// 患病类型
String diseaseType = map.get(11);
List<DiseaseType> diseaseTypes = diseaseTypeService
.findAllDiseaseTypes();
if (diseaseTypes.size() > 0) {
for (int j = 0; j < diseaseTypes.size(); j++) {
if (diseaseType.equals(diseaseTypes.get(j)
.getDiseaseType())) {
patient.setDiseaseTypeId(diseaseTypes.get(j)
.getId());
}
}
}
patientService.savePatient(patient);
}
}
return "listAction";
}


jsp代码:

<!-- 批量导入病人信息 -->
       <form class="form-horizontal" method="post" action="${pageContext.request.contextPath}/sys/patientAction_importPatient.do" id="fileUpload" name="fileUpload" enctype="multipart/form-data">
<style type="text/css">
.file {
   position: relative;
   display: inline-block;
   background: #78CD51;
   border: 1px solid #99D3F5;
   border-radius: 4px;
   padding: 4px 12px;
   
   color: #FFFFFF;
   text-decoration: none;
   text-indent: 0;
   line-height: 25px;
}
.file input {
   position: absolute;
   width:120px;
   right: 0;
   top: 0;
   opacity: 0;
}
.file:hover {
   background: #78CD51;
   border-color: #78C3F3;
   color: #FFFFFF;
   text-decoration: none;
}
</style>
<script type="text/javascript" language="javascript">
function submitFile() {
document.getElementById("fileUpload").submit();
}
</script>
<a href="javascript:;" class="file">批量导入病人信息
   <input type="file" name="filePath" id="excelFile" onChange="submitFile()">  
</a>
</form>


FileInputStream是InputStream的子类,不能直接转换,不过FileInputStream可当做InputStream来使用。
该批量导入和幼儿园管理系统导入不太一样!

这篇关于在糖尿病患者信息管理系统中,导入病人信息功能!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147029

相关文章

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

Java反射实现多属性去重与分组功能

《Java反射实现多属性去重与分组功能》在Java开发中,​​List是一种非常常用的数据结构,通常我们会遇到这样的问题:如何处理​​List​​​中的相同字段?无论是去重还是分组,合理的操作可以提高... 目录一、开发环境与基础组件准备1.环境配置:2. 代码结构说明:二、基础反射工具:BeanUtils

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3

Linux查看系统盘和SSD盘的容量、型号及挂载信息的方法

《Linux查看系统盘和SSD盘的容量、型号及挂载信息的方法》在Linux系统中,管理磁盘设备和分区是日常运维工作的重要部分,而lsblk命令是一个强大的工具,它用于列出系统中的块设备(blockde... 目录1. 查看所有磁盘的物理信息方法 1:使用 lsblk(推荐)方法 2:使用 fdisk -l(

SpringCloud使用Nacos 配置中心实现配置自动刷新功能使用

《SpringCloud使用Nacos配置中心实现配置自动刷新功能使用》SpringCloud项目中使用Nacos作为配置中心可以方便开发及运维人员随时查看配置信息,及配置共享,并且Nacos支持配... 目录前言一、Nacos中集中配置方式?二、使用步骤1.使用$Value 注解2.使用@Configur

SpringBoot如何对密码等敏感信息进行脱敏处理

《SpringBoot如何对密码等敏感信息进行脱敏处理》这篇文章主要为大家详细介绍了SpringBoot对密码等敏感信息进行脱敏处理的几个常用方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录​1. 配置文件敏感信息脱敏​​2. 日志脱敏​​3. API响应脱敏​​4. 其他注意事项​​总结

SpringBoot后端实现小程序微信登录功能实现

《SpringBoot后端实现小程序微信登录功能实现》微信小程序登录是开发者通过微信提供的身份验证机制,获取用户唯一标识(openid)和会话密钥(session_key)的过程,这篇文章给大家介绍S... 目录SpringBoot实现微信小程序登录简介SpringBoot后端实现微信登录SpringBoo

MySQL Workbench工具导出导入数据库方式

《MySQLWorkbench工具导出导入数据库方式》:本文主要介绍MySQLWorkbench工具导出导入数据库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录mysql Workbench工具导出导入数据库第一步 www.chinasem.cn数据库导出第二步