首页 > 其他分享 >项目功能--批量导入预约设置

项目功能--批量导入预约设置

时间:2024-12-05 22:42:59浏览次数:6  
标签:文件 批量 -- Excel 预约 导入 message 上传 模板

  一、需求分析
  我们需要进行预约设置,就是设置每一天的体检预约最大数量。客户可以通过微信端在线预约,在线预约时需要选择体检的时间,如果客户选择的时间已经预约满则无法进行预约。

  二、 Apache POI简介
  Apache POI是用Java编写的免费开源的跨平台的Java API,Apache POI提供API给Java程序对Microsoft Office格式档案读和写的功能,其中使用最多的就是使用POI操作Excel文件。


POI结构

HSSF - 提供读写Microsoft Excel XLS格式档案的功能
XSSF - 提供读写Microsoft Excel OOXML XLSX格式档案的功能
HWPF - 提供读写Microsoft Word DOC格式档案的功能
HSLF - 提供读写Microsoft PowerPoint格式档案的功能
HDGF - 提供读Microsoft Visio格式档案的功能
HPBF - 提供读Microsoft Publisher格式档案的功能
HSMF - 提供读Microsoft Outlook格式档案的功能

  2.1从Excel文件读取数据

使用POI可以从一个已经存在的Excel文件中读取数据,通过遍历工作表获得行,遍历行获得单元格,最终获取单元格中的值。

//创建工作簿
XSSFWorkbook workbook = new XSSFWorkbook("D:\\test.xlsx");
//获取工作表,既可以根据工作表的顺序获取,也可以根据工作表的名称获取
XSSFSheet sheet = workbook.getSheetAt(0);
//遍历工作表获得行对象
for (Row row : sheet) {
  //遍历行对象获取单元格对象
  for (Cell cell : row) {
    //获得单元格中的值
    String value = cell.getStringCellValue();
    System.out.println(value);
  }
}
workbook.close();

 


POI操作Excel表格封装了几个核心对象:
XSSFWorkbook:工作簿
XSSFSheet:工作表
Row:行
Cell:单元格

  还有一种读取方式就是获取工作表最后一个行号,从而根据行号获得行对象,通过行获取最后一个单元格索引,从而根据单元格索引获取每行的一个单元格对象,代码如下:

//创建工作簿
XSSFWorkbook workbook = new XSSFWorkbook("D:\\test.xlsx");
//获取工作表,既可以根据工作表的顺序获取,也可以根据工作表的名称获取
XSSFSheet sheet = workbook.getSheetAt(0);
//获取当前工作表最后一行的行号,行号从0开始
int lastRowNum = sheet.getLastRowNum();
for(int i=0;i<=lastRowNum;i++){
  //根据行号获取行对象
  XSSFRow row = sheet.getRow(i);
  short lastCellNum = row.getLastCellNum();
  for(short j=0;j<lastCellNum;j++){
    String value = row.getCell(j).getStringCellValue();
    System.out.println(value);
  }
}
workbook.close();

 

  2.2 向Excel文件写入数据
使用POI可以在内存中创建一个Excel文件并将数据写入到这个文件,最后通过输出流将内存中的Excel文件下载到磁盘

//在内存中创建一个Excel文件
XSSFWorkbook workbook = new XSSFWorkbook();
//创建工作表,指定工作表名称
XSSFSheet sheet = workbook.createSheet("测试");
​
//创建行,0表示第一行
XSSFRow row = sheet.createRow(0);
//创建单元格,0表示第一个单元格
row.createCell(0).setCellValue("编号");
row.createCell(1).setCellValue("名称");
row.createCell(2).setCellValue("年龄");
​
XSSFRow row1 = sheet.createRow(1);
row1.createCell(0).setCellValue("1");
row1.createCell(1).setCellValue("小明");
row1.createCell(2).setCellValue("10");
​
XSSFRow row2 = sheet.createRow(2);
row2.createCell(0).setCellValue("2");
row2.createCell(1).setCellValue("小王");
row2.createCell(2).setCellValue("20");
​
//通过输出流将workbook对象下载到磁盘
FileOutputStream out = new FileOutputStream("D:\\test.xlsx");
workbook.write(out);
out.flush();
out.close();
workbook.close();

 

  三、代码实现


批量导入预约设置信息操作过程:

1、点击模板下载按钮下载Excel模板文件

2、将预约设置信息录入到模板文件中

3、点击上传文件按钮将录入完信息的模板文件上传到服务器

4、通过POI读取上传文件的数据并保存到数据库

 

预约设置信息对应的数据表为t_ordersetting,t_ordersetting表结构:

orderDate:预约日期

number:可预约人数

reservations:已预约人数

 

步骤一: 提供模板文件
将Excel模板文件放在backend工程的template目录下

步骤二: 实现模板文件下载
为模板下载按钮绑定事件实现模板文件下载

html代码:

    <el-card class="box-card">
        <div class="boxMain">
        <el-button style="margin-bottom: 20px;margin-right: 20px" type="primary" @click="downloadTemplate()">模板下载</el-button>
        <el-upload action="/ordersetting/upload.do"
                   name="excelFile"
                   :show-file-list="false"
                   :on-success="handleSuccess"
                   :before-upload="beforeUpload">
            <el-button type="primary">上传文件</el-button>
        </el-upload>
    </div>
    <div>
        操作说明:请点击"模板下载"按钮获取模板文件,在模板文件中录入预约设置数据后点击"上传文件"按钮上传模板文件。
    </div>
</el-card>

javascript代码:

//上传之前进行文件格式校验
    beforeUpload(file){
        const isXLS = file.type === 'application/vnd.ms-excel';
        if(isXLS){
            return true;
        }
        const isXLSX = file.type === 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet';
        if (isXLSX) {
            return true;
        }
        this.$message.error('上传文件只能是xls或者xlsx格式!');
        return false;
    },
    //下载模板文件
    downloadTemplate(){
        window.location.href="../../template/ordersetting_template.xlsx";
    },
    //上传成功提示
    handleSuccess(response, file) {
        if(response.flag){
            this.$message({
                message: response.message,
                type: 'success'
            });
        }else{
            this.$message.error(response.message);
        }
        console.log(response, file, fileList);
    },

 



 

步骤三: 文件上传
使用ElementUI的上传组件实现文件上传并绑定相关事件

html代码:

 <el-card class="box-card">
        <div class="boxMain">
        <el-button style="margin-bottom: 20px;margin-right: 20px" type="primary" @click="downloadTemplate()">模板下载</el-button>
        <el-upload action="/ordersetting/upload.do"
                   name="excelFile"
                   :show-file-list="false"
                   :on-success="handleSuccess"
                   :before-upload="beforeUpload">
            <el-button type="primary">上传文件</el-button>
        </el-upload>
    </div>
    <div>
        操作说明:请点击"模板下载"按钮获取模板文件,在模板文件中录入预约设置数据后点击"上传文件"按钮上传模板文件。
    </div>
</el-card>

 


javascript代码:

//上传之前进行文件格式校验
    beforeUpload(file){
        const isXLS = file.type === 'application/vnd.ms-excel';
        if(isXLS){
            return true;
        }
        const isXLSX = file.type === 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet';
        if (isXLSX) {
            return true;
        }
        this.$message.error('上传文件只能是xls或者xlsx格式!');
        return false;
    },
    //下载模板文件
    downloadTemplate(){
        window.location.href="../../template/ordersetting_template.xlsx";
    },
    //上传成功提示
    handleSuccess(response, file) {
        if(response.flag){
            this.$message({
                message: response.message,
                type: 'success'
            });
        }else{
            this.$message.error(response.message);
        }
        console.log(response, file, fileList);
    },

 

步骤四: Controller

在common工程中,编写POIUtils工具类,在backend工程创建Controller并提供upload方法处理

    /**
     * Excel文件上传,解析文件内容保存到数据库,实现预约设置数据批量导入
     * @param excelFile
     * @return
     */
    @RequestMapping("/upload")
    public Result upload(@RequestParam("excelFile")MultipartFile excelFile){
 
        try {
            List<String[]> list = POIUtils.readExcel(excelFile);//使用POI解析表格数据
            if(list != null && list.size() > 0){
                List<OrderSetting> orderSettingList = new ArrayList<>();
                for (String[] strings : list) {
                    OrderSetting orderSetting =
                            new OrderSetting(new Date(strings[0]), Integer.parseInt(strings[1]));
                    orderSettingList.add(orderSetting);
                }
                orderSettingService.add(orderSettingList);
            }
        } catch (IOException e) {
            e.printStackTrace();
            return new Result(false, MessageConstant.IMPORT_ORDERSETTING_FAIL);
        }
        return new Result(true,MessageConstant.IMPORT_ORDERSETTING_SUCCESS);
    }

 

 

步骤五:编写OrderSettingService 服务接口和服务实现类

为了避免重复导入,需要先判断当前日期是否已经进行设置,如果没有进行预约设置直接insert新增设置,如果已经进行预约设置就需要更新设置。

服务接口:

import com.it.pojo.OrderSetting;
import java.util.List;
import java.util.Map;
​
public interface OrderSettingService {
    public void add(List<OrderSetting> list);
}

 


服务实现类:

/**
 * 预约设置服务
 */
@Service(interfaceClass = OrderSettingService.class)
@Transactional
public class OrderSettingServiceImpl implements OrderSettingService {
    @Autowired
    private OrderSettingDao orderSettingDao;
    //批量添加
    public void add(List<OrderSetting> list) {
        if(list != null && list.size() > 0){
            for (OrderSetting orderSetting : list) {
                //检查此数据(日期)是否存在
                long count = orderSettingDao.findCountByOrderDate(orderSetting.getOrderDate());
                if(count > 0){
                    //已经存在,执行更新操作
                    orderSettingDao.editNumberByOrderDate(orderSetting);
                }else{
                    //不存在,执行添加操作
                    orderSettingDao.add(orderSetting);
                }
            }
        }
    }
}

 

步骤六:编写Dao接口和实现

实现完成,启动项目运行测试批量导入预约设置。

标签:文件,批量,--,Excel,预约,导入,message,上传,模板
From: https://www.cnblogs.com/kongsq/p/18589590

相关文章

  • 鼠标键盘游戏手柄的测试代码
    #include"QtWidgetsApplication2.h"#include<windows.h>#include<QDebug>#include<QVBoxLayout>QtWidgetsApplication2::QtWidgetsApplication2(QWidget*parent):QFrame(parent){ui.setupUi(this); //init();}QtWidget......
  • manim边做边学--多面体
    在Manim中,对于多面体,有一系列封装好的类可以直接使用。使用它们,可以方便快速的构建正多面体:Polyhedron:通过顶点和面的参数构建任意多面体Tetrahedron:四面体Octahedron:八面体Dodecahedron:十二面体Icosahedron:二十面体这些类使得在动画中直观地展示多面体成为可能,有助于理......
  • 电商项目--分布式文件存储FastDFS搭建
    一、FastDFS环境搭建我们使用Docker搭建FastDFS的开发环境(1)拉取镜像dockerpullmorunchang/fastdfs (2)运行trackerdockerrun-d--nametracker--net=hostmorunchang/fastdfsshtracker.sh(3)运行storagedockerrun-d--namestorage--net=host-eTRACKER_......
  • pinia 持久化存储库pinia-plugin-persist使用
    对于Vue3和Pinia,有一个名为pinia-plugin-persist的插件可以用来持久化Piniastore的状态到localStorage或sessionStorage。这个插件简化了状态持久化的过程,使得你不需要手动编写保存和加载状态的逻辑。以下是如何使用pinia-plugin-persist插件来持久化Piniastore......
  • DSP 的 CV 算子调用
    01前言DSP是征程5上的数字信号处理器,专用于处理视觉、图像等信息。在OE包的ddk/samples/vdsp_rpc_sample路径下,提供了DSP使用示例,包括nn和CV两部分。nn示例涵盖了深度学习模型的相关算子,包括量化、反量化、Softmax和雷达点云预处理;CV示例展示了如何调用地平线......
  • js 如何操作IndexedDB 存储
    IndexedDB是一种在用户浏览器中存储大量结构化数据的方式。它是一个低级API,用于在客户端存储大量数据,并使用索引来进行高性能搜索。以下是如何在前端JavaScript中使用IndexedDB的基本步骤:1.打开数据库首先,你需要打开一个数据库。如果数据库不存在,它会自动创建。letdb;......
  • linux命令
    1.查看当前目录  ls:-l 以列表方式显示-h以大小单位显示,默认字节为单位-a显示隐藏目录和隐藏文件2.以树状方式显示目录信息 tree3.查看当前目录路径  pwd4.清楚终端内容   clear5.切换目录命......
  • 小程序内嵌web-view缓存
    现状:项目是通过web-view内嵌在小程序里的H5页面,然而发布新版本之后,在小程序入口进去看到的还是旧页面原因:通用缓存原理浏览器每次发起请求,都会先在浏览器缓存中查找该请求的结果以及缓存标识浏览器每次拿到返回的请求结果都会将该结果和缓存标识存入浏览器缓存web-view组......
  • 电商项目-跨域解决方案CORS
    一、什么是跨域出于浏览器的同源策略限制。同源策略(Sameoriginpolicy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响。可以说Web是构建在同源策略基础之上的,浏览器只是针对同源策略的一种实现。同源策略......
  • 一个js文件导出一个new class实例,其他多个地方import引用的是同一个实例对象吗
    在JavaScript中,当你从一个模块导出一个类的实例时,其他模块在导入这个实例时将获得该实例的一个引用。这意味着,如果你修改了这个实例的属性或调用它的方法,所有导入该实例的模块都会看到这些更改,因为它们引用的是同一个对象。以下是一个示例:moduleA.js:classMyClass{const......