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

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

相关文章

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

C#实现获取电脑中的端口号和硬件信息

《C#实现获取电脑中的端口号和硬件信息》这篇文章主要为大家详细介绍了C#实现获取电脑中的端口号和硬件信息的相关方法,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 我们经常在使用一个串口软件的时候,发现软件中的端口号并不是普通的COM1,而是带有硬件信息的。那么如果我们使用C#编写软件时候,如

基于WinForm+Halcon实现图像缩放与交互功能

《基于WinForm+Halcon实现图像缩放与交互功能》本文主要讲述在WinForm中结合Halcon实现图像缩放、平移及实时显示灰度值等交互功能,包括初始化窗口的不同方式,以及通过特定事件添加相应... 目录前言初始化窗口添加图像缩放功能添加图像平移功能添加实时显示灰度值功能示例代码总结最后前言本文将

通过C#获取PDF中指定文本或所有文本的字体信息

《通过C#获取PDF中指定文本或所有文本的字体信息》在设计和出版行业中,字体的选择和使用对最终作品的质量有着重要影响,然而,有时我们可能会遇到包含未知字体的PDF文件,这使得我们无法准确地复制或修改文... 目录引言C# 获取PDF中指定文本的字体信息C# 获取PDF文档中用到的所有字体信息引言在设计和出

Python数据处理之导入导出Excel数据方式

《Python数据处理之导入导出Excel数据方式》Python是Excel数据处理的绝佳工具,通过Pandas和Openpyxl等库可以实现数据的导入、导出和自动化处理,从基础的数据读取和清洗到复杂... 目录python导入导出Excel数据开启数据之旅:为什么Python是Excel数据处理的最佳拍档

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用

C#读取本地网络配置信息全攻略分享

《C#读取本地网络配置信息全攻略分享》在当今数字化时代,网络已深度融入我们生活与工作的方方面面,对于软件开发而言,掌握本地计算机的网络配置信息显得尤为关键,而在C#编程的世界里,我们又该如何巧妙地读取... 目录一、引言二、C# 读取本地网络配置信息的基础准备2.1 引入关键命名空间2.2 理解核心类与方法

最好用的WPF加载动画功能

《最好用的WPF加载动画功能》当开发应用程序时,提供良好的用户体验(UX)是至关重要的,加载动画作为一种有效的沟通工具,它不仅能告知用户系统正在工作,还能够通过视觉上的吸引力来增强整体用户体验,本文给... 目录前言需求分析高级用法综合案例总结最后前言当开发应用程序时,提供良好的用户体验(UX)是至关重要

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur