Apache POI 与 Alibaba EasyExcel 的使用

  • Apache POI
<dependencies><!-- xls(03) --><dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>3.9</version></dependency><!-- xls(07) --><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>3.9</version></dependency><!-- 日期格式化工具 --><dependency><groupId>joda-time</groupId><artifactId>joda-time</artifactId><version>2.10.1</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency>
</dependencies>
  • 测试写(03版)
String Path = "D:\\data\\";@Test
public void testWrite03() throws Exception {// 创建工作簿对象 03Workbook workbook = new HSSFWorkbook();// 创建一个工作表Sheet sheet0 = workbook.createSheet("BLU测试表");// 创建一行Row row0 = sheet0.createRow(0);// 创建一个单元格Cell cell00 = row0.createCell(0);cell00.setCellValue("编号");Cell cell01 = row0.createCell(1);cell01.setCellValue("姓名");Row row1 = sheet0.createRow(1);Cell cell10 = row1.createCell(0);cell10.setCellValue(1);Cell cell11 = row1.createCell(1);cell11.setCellValue("BLU");Cell cell12 = row1.createCell(2);String time = new DateTime().toString("yyyy-MM-dd HH:mm:ss");cell12.setCellValue(time);FileOutputStream fos = new FileOutputStream(Path + "test03.xls");workbook.write(fos);fos.close();System.out.println("文件生成完毕");
}

在这里插入图片描述

  • 测试写(07版)
String Path = "D:\\data\\";@Test
public void testWrite07() throws Exception {Workbook workbook = new XSSFWorkbook();Sheet sheet0 = workbook.createSheet("BLU测试表");Row row0 = sheet0.createRow(0);Cell cell00 = row0.createCell(0);cell00.setCellValue("编号");Cell cell01 = row0.createCell(1);cell01.setCellValue("姓名");Row row1 = sheet0.createRow(1);Cell cell10 = row1.createCell(0);cell10.setCellValue(1);Cell cell11 = row1.createCell(1);cell11.setCellValue("BLU");Cell cell12 = row1.createCell(2);String time = new DateTime().toString("yyyy-MM-dd HH:mm:ss");cell12.setCellValue(time);FileOutputStream fos = new FileOutputStream(Path + "test07.xlsx");workbook.write(fos);fos.close();System.out.println("文件生成完毕");
}

在这里插入图片描述

  • 测试大数据写入(03版)
String Path = "D:\\data\\";/*** 65536行数据耗时:2.815s * 最多只能创建65536行*/@Test
public void testWrite03BigData() throws Exception {long begin = System.currentTimeMillis();HSSFWorkbook workbook = new HSSFWorkbook();Sheet sheet = workbook.createSheet();for (int rowNum = 0; rowNum < 65536; rowNum++) {Row row = sheet.createRow(rowNum);for (int cellNum = 0; cellNum < 10; cellNum++) {Cell cell = row.createCell(cellNum);cell.setCellValue(cellNum);}}System.out.println("over");FileOutputStream fos = new FileOutputStream(Path + "testWrite03BigData.xls");workbook.write(fos);fos.close();long end = System.currentTimeMillis();System.out.println((double) (end - begin) / 1000);
}
  • 测试大数据写入(07版)
String Path = "D:\\data\\";/*** 65536行数据耗时6.843s* 10万行数据耗时13.028s* 内存占用大*/@Test
public void testWrite07BigData() throws Exception {long begin = System.currentTimeMillis();XSSFWorkbook workbook = new XSSFWorkbook();Sheet sheet = workbook.createSheet();for (int rowNum = 0; rowNum < 100000; rowNum++) {Row row = sheet.createRow(rowNum);for (int cellNum = 0; cellNum < 10; cellNum++) {Cell cell = row.createCell(cellNum);cell.setCellValue(cellNum);}}System.out.println("over");FileOutputStream fos = new FileOutputStream(Path + "testWrite07BigData.xlsx");workbook.write(fos);fos.close();long end = System.currentTimeMillis();System.out.println((double) (end - begin) / 1000);}
  • 使用 SXSSFWorkbook 测试大数据写入
String Path = "D:\\data\\";/*** 10万行数据耗时1.916s*/@Test
public void testWrite07BigDataS() throws Exception {long begin = System.currentTimeMillis();SXSSFWorkbook workbook = new SXSSFWorkbook();Sheet sheet = workbook.createSheet();for (int rowNum = 0; rowNum < 100000; rowNum++) {Row row = sheet.createRow(rowNum);for (int cellNum = 0; cellNum < 10; cellNum++) {Cell cell = row.createCell(cellNum);cell.setCellValue(cellNum);}}System.out.println("over");FileOutputStream fos = new FileOutputStream(Path + "testWrite07BigDataS.xlsx");workbook.write(fos);fos.close();// 清除临时文件workbook.dispose();long end = System.currentTimeMillis();System.out.println((double) (end - begin) / 1000);
}
  • 测试读(03版)
String Path = "D:\\data\\";@Test
public void testRead03() throws Exception {FileInputStream fis = new FileInputStream(Path + "test03.xls");Workbook workbook = new HSSFWorkbook(fis);Sheet sheet = workbook.getSheetAt(0);Row row = sheet.getRow(1);Cell cell0 = row.getCell(0);double value0 = cell0.getNumericCellValue();System.out.println(value0);Cell cell1 = row.getCell(1);String value1 = cell1.getStringCellValue();System.out.println(value1);fis.close();
}
1.0
BLU
  • 测试读(07版)
String Path = "D:\\data\\";@Test
public void testRead07() throws Exception {FileInputStream fis = new FileInputStream(Path + "test07.xlsx");Workbook workbook = new XSSFWorkbook(fis);Sheet sheet = workbook.getSheetAt(0);Row row = sheet.getRow(1);Cell cell0 = row.getCell(0);double value0 = cell0.getNumericCellValue();System.out.println(value0);Cell cell1 = row.getCell(1);String value1 = cell1.getStringCellValue();System.out.println(value1);fis.close();
}
1.0
BLU
  • 根据数据类型读取的示例:

BLU.xls文件:
在这里插入图片描述

String Path = "D:\\data\\";@Test
public void testCellType() throws Exception {FileInputStream fis = new FileInputStream(Path + "BLU.xls");Workbook workbook = new HSSFWorkbook(fis);Sheet sheet = workbook.getSheetAt(0);Row rowTitle = sheet.getRow(0);if (rowTitle != null) {int cellCount = rowTitle.getPhysicalNumberOfCells();for (int cellNum = 0; cellNum < cellCount; cellNum++) {Cell cell = rowTitle.getCell(cellNum);if (cell != null) {String cellValue = cell.getStringCellValue();System.out.print(cellValue + " | ");}}}System.out.println();int rowCount = sheet.getPhysicalNumberOfRows();for (int rowNum = 1; rowNum < rowCount; rowNum++) {Row rowData = sheet.getRow(rowNum);if (rowData != null) {int cellCount = rowData.getPhysicalNumberOfCells();for (int cellNum = 0; cellNum < cellCount; cellNum++) {Cell cell = rowData.getCell(cellNum);if (cell != null) {int cellType = cell.getCellType();switch (cellType) {case HSSFCell.CELL_TYPE_STRING:System.out.print(cell.getStringCellValue());break;case HSSFCell.CELL_TYPE_BOOLEAN:System.out.print(String.valueOf(cell.getBooleanCellValue()));break;case HSSFCell.CELL_TYPE_BLANK:break;case HSSFCell.CELL_TYPE_NUMERIC:if(HSSFDateUtil.isCellDateFormatted(cell)) {Date date = cell.getDateCellValue();String s = new DateTime(date).toString("yyyy-MM-dd");System.out.print(s);}else {cell.setCellType(HSSFCell.CELL_TYPE_STRING);System.out.print(cell.toString());}break;case HSSFCell.CELL_TYPE_ERROR:break;}System.out.print(" | ");}}System.out.println();}}fis.close();
}
手机号 | 日期 | 订单号 | 商品编号 | 商品名称 | 价格 | 销售数量 | 销售金额 | 已发货 | 
15651776666 | 2020-09-30 | 000001 | 1 | 蒙牛 | 65.5 | 1 | 65.5 | true | 
15651776666 | 2020-10-01 | 000002 | 2 | 脑白金 | 100 | 10 | 1000 | false | 
  • 读取计算函数的示例:

func.xls文件:
在这里插入图片描述

String Path = "D:\\data\\";@Test
public void testFormula() throws Exception {FileInputStream fis = new FileInputStream(Path + "func.xls");Workbook workbook = new HSSFWorkbook(fis);Sheet sheet = workbook.getSheetAt(0);Row row = sheet.getRow(4);Cell cell = row.getCell(0);FormulaEvaluator formulaEvaluator = new HSSFFormulaEvaluator((HSSFWorkbook) workbook);int cellType = cell.getCellType();switch(cellType) {case Cell.CELL_TYPE_FORMULA:String formula = cell.getCellFormula();System.out.println(formula);CellValue evaluate = formulaEvaluator.evaluate(cell);String cellValue = evaluate.formatAsString();System.out.println(cellValue);break;}}
SUM(A2:A4)
600.0

  • Alibaba EasyExcel
<dependencies><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>2.2.0-beta2</version></dependency><!-- 日期格式化工具 --><dependency><groupId>joda-time</groupId><artifactId>joda-time</artifactId><version>2.10.1</version></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.12</version></dependency><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.62</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency>	</dependencies>
  • 实体类:
package com.blu.easy;import java.util.Date;
import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;@Data
public class DemoData {@ExcelProperty("字符串标题")private String string;@ExcelProperty("日期标题")private Date date;@ExcelProperty("数字标题")private Double doubleData;/*** 忽略这个字段*/@ExcelIgnoreprivate String ignore;
}
  • 监听器:
package com.blu.easy;import java.util.ArrayList;
import java.util.List;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.alibaba.fastjson.JSON;public class DemoDataListener extends AnalysisEventListener<DemoData> {private static final Logger LOGGER = LoggerFactory.getLogger(DemoDataListener.class);private static final int BATCH_COUNT = 5;List<DemoData> list = new ArrayList<DemoData>();private DemoDAO demoDAO;public DemoDataListener() {demoDAO = new DemoDAO();}public DemoDataListener(DemoDAO demoDAO) {this.demoDAO = demoDAO;}@Overridepublic void invoke(DemoData data, AnalysisContext context) {System.out.println(JSON.toJSONString(data));list.add(data);// 达到BATCH_COUNT了,需要去存储一次数据库,防止数据几万条数据在内存,容易OOMif (list.size() >= BATCH_COUNT) {saveData();// 存储完成清理 listlist.clear();}}/*** 所有数据解析完成了 都会来调用** @param context*/@Overridepublic void doAfterAllAnalysed(AnalysisContext context) {// 这里也要保存数据,确保最后遗留的数据也存储到数据库saveData();LOGGER.info("所有数据解析完成!");}/*** 加上存储数据库*/private void saveData() {LOGGER.info("{}条数据,开始存储数据库!", list.size());demoDAO.save(list);LOGGER.info("存储数据库成功!");}
}
  • DAO:
package com.blu.easy;import java.util.List;/*** 假设这个是你的DAO存储。当然还要这个类让spring管理,当然你不用需要存储,也不需要这个类。**/
public class DemoDAO {public void save(List<DemoData> list) {// 持久化操作// 如果是mybatis,尽量别直接调用多次insert,自己写一个mapper里面新增一个方法batchInsert,所有数据一次性插入}
}
  • 测试:
package com.blu.easy;import java.util.ArrayList;
import java.util.Date;
import java.util.List;import org.junit.Test;import com.alibaba.excel.EasyExcel;public class EasyTest {String Path = "D:\\data\\";private List<DemoData> data() {List<DemoData> list = new ArrayList<DemoData>();for (int i = 0; i < 10; i++) {DemoData data = new DemoData();data.setString("字符串" + i);data.setDate(new Date());data.setDoubleData(0.56);list.add(data);}return list;}/*** 最简单的写*/@Testpublic void simpleWrite() {String fileName = Path + "easyTest.xlsx";EasyExcel.write(fileName, DemoData.class).sheet("模板").doWrite(data());}/*** 最简单的读*/@Testpublic void simpleRead() {// 有个很重要的点 DemoDataListener 不能被spring管理,要每次读取excel都要new,然后里面用到spring可以构造方法传进去String fileName = Path + "easyTest.xlsx";// 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭EasyExcel.read(fileName, DemoData.class, new DemoDataListener()).sheet().doRead();}}

写入结果:
在这里插入图片描述
读取结果:

{"date":1601434567000,"doubleData":0.56,"string":"字符串0"}
{"date":1601434567000,"doubleData":0.56,"string":"字符串1"}
{"date":1601434567000,"doubleData":0.56,"string":"字符串2"}
{"date":1601434567000,"doubleData":0.56,"string":"字符串3"}
{"date":1601434567000,"doubleData":0.56,"string":"字符串4"}
{"date":1601434567000,"doubleData":0.56,"string":"字符串5"}
{"date":1601434567000,"doubleData":0.56,"string":"字符串6"}
{"date":1601434567000,"doubleData":0.56,"string":"字符串7"}
{"date":1601434567000,"doubleData":0.56,"string":"字符串8"}
{"date":1601434567000,"doubleData":0.56,"string":"字符串9"}
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 开源=免费?

    直接给出结论&#xff0c;开源和免费是不同概念&#xff1a; 开源是指开放源代码。所以开源软件在发布时会公开软件源码&#xff0c;并允许使用者利用其源码进行优化、传播以及二次开发。 而免费软件则是免费提供给用户使用的软件&#xff0c;不过虽是免费&#xff0c;但通常…...

    2024/4/15 12:40:59
  2. 自学C语言,自主研发软件,“第一代”程序员!

    你好哇&#xff0c;李银河。 一想到你&#xff0c;我这张丑脸上就泛起微笑。” 喜欢读书的人&#xff0c;对王小波都不陌生。但很少有人知道王小波是中国早期可以说是“第一代”的程序员。 王小波在自己的杂文集《沉默的大多数》中<科学的美好>写到&#xff1a; “我现在…...

    2024/4/28 1:08:21
  3. Java8-新特性

    Java8-新特性 1. Lambda表达式 为什么要使用Lambda表达式 Lambda 是一个匿名函数&#xff0c;我们可以把 Lambda 表达式理解为是一段可以传递的代码&#xff08;将代码像数据一样进行传递&#xff09;。使用它可以写出更简洁、更灵活的代码。作为一种更紧凑的代码风格&#xf…...

    2024/4/1 12:38:42
  4. 工业自动化OPC/OPC UA

    OPC是工业自动化领域用得比较多的协议。 在经典的且程序化的说法是&#xff1a;O LE for P rocess C ontrol&#xff08;用于过程控制的OLE&#xff09;。OLE 或对象链接和嵌入是Windows的基本早期构建块&#xff0c;允许应用程序在它们之间共享复杂的信息。 也可以叫O pen P…...

    2024/4/1 12:38:40
  5. 苹果企业签名需要注意的最大问题,很多人会忽略

    苹果手机用户都知道&#xff0c;下载应用都是在AppStore里&#xff0c;但是想要将自己的应用上架到AppStore是一件非常困难的事&#xff0c;对于无法上架到AppStore的应用来说&#xff0c;通过苹果签名这种内测分发渠道来完成app的上架任务几乎是每一个开发者的选择。 苹果签名…...

    2024/4/25 5:35:07
  6. windows 10 docker安装及使用

    关于docker和虚拟机的比较&#xff1a; 一、启用Hyper-V 环境准备Docker for Windows是一个Docker Community Edition&#xff08;CE&#xff09;应用程序。Docker for Windows安装包包含了在Windows系统上运行Docker所需的一切。如果你不想装虚拟机&#xff0c;想直接在你的…...

    2024/4/1 12:38:38
  7. echarts单行柱状图

    <!DOCTYPE html> <html><head><meta charset"utf-8"><title>柱状图</title><!-- 引入 echarts.js --><script src"js/echarts.min.js"></script> </head><body><!-- 为ECharts准备一…...

    2024/4/23 4:27:36
  8. 测试小记

    测试小记 搭建环境 python3.7&#xff08;之前已安装&#xff09;pyCharm&#xff08;之前已安装&#xff09;浏览器驱动 熟悉语法 python-selenium&#xff08;现学&#xff09;HTML & CSS 问题与解决方法 问题1 &#xff1a;登录之后&#xff0c;新页面的元素无法被…...

    2024/4/23 12:55:38
  9. wordpress输出导航菜单

    定义导航菜单 在主题根目录functions.php键入如下代码 注册菜单 register_nav_menus(array(PrimaryMenu>导航,friendlinks>友情链接,footer_nav>页脚导航));add_theme_support(nav_menus); 键为菜单别名&#xff0c;值为后台显示 加上这段代码我们就可以在后台控制菜…...

    2024/4/1 11:41:38
  10. 增加用例评审及思维导图导入功能,MeterSphere开源持续测试平台v1.3.0发布丨Release Notes

    9月29日&#xff0c;MeterSphere开源持续测试平台正式发布v1.3.0版本。在该版本中&#xff0c;MeterSphere主要针对测试跟踪及接口测试模块进行了功能更新及优化。 在测试跟踪模块中&#xff0c;我们增加了全新的用例评审功能&#xff0c;用户可选择部分或全部用例发起评审&am…...

    2024/4/22 19:27:54
  11. Anaconda 环境创建

    这里写自定义目录标题anaconda 添加环境到指定目录&#xff0c;原因默认目录不太灵活&#xff0c;长期使用&#xff0c;容易占满该分区硬盘 创建环境&#xff0c;环境所在目录为/data/garbage conda create --prefix/data/garbage python3.6 激活环境 conda activate /data/gar…...

    2024/4/1 11:41:36
  12. 运行sumocfg文件时出现的错误及解决办法

    SUMO使用中出现的错误 1.运行.sumocfg文件时&#xff0c;如果出现erro:whitespace等等错误&#xff0c;这是由于.rou.xml文件中代码错误导致&#xff0c;这时重写代码就可以了 2.在用netedit绘制路网时&#xff0c;如果出现数字键盘失灵的情况ia&#xff0c;这是因为使用了win…...

    2024/4/25 7:17:44
  13. 进程的切换和系统的一般执行过程

    进程的调度时机与进程的切换 操作系统原理中介绍了大量进程调度算法&#xff0c;这些算法从实现的角度看仅仅是从运行队列中选择一个新进程&#xff0c;选择的过程中运用了不同的策略而已。 对于理解操作系统的工作机制&#xff0c;反而是进程的调度时机与进程的切换机制更为…...

    2024/4/1 11:41:34
  14. Python 爬取百度翻译使用requests模块发送post请求时-发生异常997

    原因&#xff1a;主要是sign与Cookie&#xff0c;每次重新输入字符串的时候就会发生变化 解决&#xff1a;必须要添加对应的Cookie,才可以取到数据&#xff0c;否则就发生异常997 首先&#xff1a;使用Android的方式&#xff1a; 查看&#xff1a; 代码&#xff1a;使用JSON将…...

    2024/4/22 8:09:52
  15. vue3.0 + UEditor

    1.下载UEditor相关静态文件 下载地址&#xff1a;UEditor 2.修改UEditor目录 并引入项目 下载下来的UEditor包&#xff0c;解压之后&#xff0c;名称是带着版本号的&#xff0c;为了看上去简洁一些&#xff0c;可以修改名字&#xff0c;比如UE 。将解压完并顺利改完名字的UE…...

    2024/4/17 3:07:13
  16. 14.加一(简单)

    给定一个由整数组成的非空数组所表示的非负整数&#xff0c;在该数的基础上加一。 最高位数字存放在数组的首位&#xff0c; 数组中每个元素只存储单个数字。 你可以假设除了整数 0 之外&#xff0c;这个整数不会以零开头。 示例 1: 输入: [1,2,3] 输出: [1,2,4] 解释: 输入…...

    2024/4/26 14:58:57
  17. redisTemplate 乱码 redis乱码

    如果是像这种&#xff0c;那么不是乱码&#xff0c;如果想看到具体的key&#xff0c;不是这种看不懂的符号&#xff0c;那么要使用 StringRedisTemplate&#xff0c;而不是redisTemplate...

    2024/4/13 18:06:57
  18. linux(ubuntu)下英伟达Nvidia 显卡监控工具nvtop使用方法

    文章目录一、问题背景二、nvtop命令一、问题背景 我们常用nvidia-smi指令来查看显卡的使用情况&#xff0c;这种方法可以看出每张显卡内存和GPU利用率的实时情况&#xff0c;但看不出历史数据和变化曲线&#xff0c;这个时候就需要用到nvtop了。 二、nvtop命令 Nvtop代表NVi…...

    2024/5/3 1:11:42
  19. Java爬虫学习——使用Jsoup对抓取到的页面分析

    jsoup 是一款Java 的HTML解析器&#xff0c;可直接解析某个URL地址、HTML文本内容。它提供了一套非常省力的API&#xff0c;可通过DOM&#xff0c;CSS以及类似于jQuery的操作方法来取出和操作数据。 导入maven依赖 <!--Jsoup--> <dependency><groupId>org.…...

    2024/5/3 13:14:56
  20. Python用到的编辑器那些比较合适新手使用呢?你会使用那些!

    新手学Python用什么编辑器比较好?工欲善其事必先利其器&#xff0c;选好工具学习更高效。市面上流行的编辑器众多&#xff0c;根据自己的需求选择适合自己。p小白可以选择pycharm配置简单功能强大使用起来省时省心&#xff0c;对初学者非常友好。今天主要介绍SublimeText、IDL…...

    2024/4/29 6:06:08

最新文章

  1. Vue在/public目录下访问process.env.NODE_ENV(其它通用)

    总所周知,/public目录下的js文件是不会经过webpack处理的. 所以process.env.NODE_ENV 也无效.无法判断,当要根据这个去判断的时候就麻烦了. 但有个办法可以解决这个问题. 先安装 npm install --save-dev cross-env 就是在index.html里面去赋值到window变量中,如下 在 /pu…...

    2024/5/4 18:43:10
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 09 spring-boot-acurator 定时检测 redis 集群导致 “IOException: Too many open files“

    前言 问题的现象主要是如下 项目刚启动的时候 十分正常, 然后 随着时间的推移, 比如说 项目跑了 四五天之后 项目 突然出现问题, 一部分服务能够正常访问, 一部分服务抛出异常 异常信息 就是 too many files 这里的主要的问题是 在异常之前, redis 集群没有密码, 然后 …...

    2024/4/30 8:18:44
  4. JVM学习笔记

    文章目录 一、内存模型1. 程序计数器2. 栈3. 本地方法栈4. 堆5. 方法区方法区位置字符串常量池位置 6. 直接内存 二、虚拟机参数设置三、类的生命周期1. 加载2. 连接1&#xff09;验证2&#xff09;准备3&#xff09;解析 3. 初始化4. 卸载 四、类加载器1. 启动类加载器2. 扩展…...

    2024/5/1 13:33:02
  5. 整理的微信小程序日历(单选/多选/筛选)

    一、日历横向多选&#xff0c;支持单日、双日、三日、工作日等选择 效果图 wxml文件 <view class"calendar"><view class"section"><view class"title flex-box"><button bindtap"past">上一页</button&…...

    2024/5/1 13:16:44
  6. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/4 12:05:22
  7. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/5/4 11:23:32
  8. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/5/4 14:46:16
  9. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/3 16:00:51
  10. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/5/4 12:10:13
  11. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/5/3 21:22:01
  12. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/3 23:17:01
  13. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/4 14:46:12
  14. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/4 14:46:11
  15. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/5/4 14:46:11
  16. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/5/4 2:14:16
  17. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/3 16:23:03
  18. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/5/4 12:39:12
  19. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/5/4 13:16:06
  20. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/4 16:48:41
  21. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/4 14:46:05
  22. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/5/4 2:00:16
  23. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/3 22:03:11
  24. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/4 9:07:39
  25. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/5/4 14:46:02
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57