POI及EasyExcel学习笔记

POI及EasyExcel学习笔记

组件、工具

POI-Excel概述

Apache POI

  • 结构:
    • HSSF - 提供读写[Microsoft Excel](https://baike.baidu.com/item/Microsoft Excel)格式档案的功能。
    • XSSF - 提供读写Microsoft Excel OOXML格式档案的功能。
    • HWPF - 提供读写[Microsoft Word](https://baike.baidu.com/item/Microsoft Word)格式档案的功能。
    • HSLF - 提供读写Microsoft PowerPoint格式档案的功能。
    • HDGF - 提供读写[Microsoft Visio](https://baike.baidu.com/item/Microsoft Visio)格式档案的功能。

easyExcel

官网:https://github.com/alibaba/easyexcel

介绍:

image-20210903092705064

POI-Excel写

创建项目

导入依赖

<!-- xls(03) -->
<dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>3.17</version>
</dependency>
<!-- xls(07) -->
<dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>3.17</version>
</dependency>
<!-- 日期格式化工具 -->
<dependency><groupId>joda-time</groupId><artifactId>joda-time</artifactId><version>2.10.6</version>
</dependency>
<!-- test -->
<dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope>
</dependency>

一、Execl概述

03版的xls,最多只能放65536条数据

07版的xlsx,没有数据条数的限制

它们对应的工具类也不相同

image-20210903104857339

工作簿 ==> 工作表

03版本

    String PATH = "C:\\Users\\DingYifan\\Desktop\\PROJECTS\\PoiAndExecl\\";@Test// 03public void testWrite03() throws IOException {// 1.创建一个工作簿(对象)Workbook workbook = new HSSFWorkbook();// 2.创建一个工作表Sheet sheet = workbook.createSheet("赶快去学习!表");// 3.创建一个行 (1,1)Row row1 = sheet.createRow(0);// 4.创建一个单元格Cell cell11 = row1.createCell(0);cell11.setCellValue("今天你学习了吗");Cell cell12 = row1.createCell(1);cell12.setCellValue("今天我学习了吗");Cell cell13 = row1.createCell(2);cell13.setCellValue("今天他学习了吗");// 创建第二个行Row row2 = sheet.createRow(1);Cell cell21 = row2.createCell(0);cell21.setCellValue("今天小狗学习了吗");Cell cell22 = row2.createCell(1);cell22.setCellValue("今天小猫学习了吗");// 日期Cell cell23 = row2.createCell(2);;String time = new DateTime().toString("yyyy-MM-dd HH:mm:ss");cell23.setCellValue(time);// 生成一张表(IO流) 03版本就是使用xls结尾!FileOutputStream fileOutputStream = new FileOutputStream(PATH + "阿巴阿巴你学习了吗.xls");// 输出workbook.write(fileOutputStream);// 关闭流fileOutputStream.close();System.out.println("Execl生成完毕");}

07版本

    @Test// 07public void testWrite07() throws IOException {// 1.创建一个工作簿(对象)Workbook workbook = new XSSFFWorkbook();// 2.创建一个工作表Sheet sheet = workbook.createSheet("赶快去学习!表");// 3.创建一个行 (1,1)Row row1 = sheet.createRow(0);// 4.创建一个单元格Cell cell11 = row1.createCell(0);cell11.setCellValue("今天你学习了吗");Cell cell12 = row1.createCell(1);cell12.setCellValue("今天我学习了吗");Cell cell13 = row1.createCell(2);cell13.setCellValue("今天他学习了吗");// 创建第二个行Row row2 = sheet.createRow(1);Cell cell21 = row2.createCell(0);cell21.setCellValue("今天小狗学习了吗");Cell cell22 = row2.createCell(1);cell22.setCellValue("今天小猫学习了吗");// 日期Cell cell23 = row2.createCell(2);;String time = new DateTime().toString("yyyy-MM-dd HH:mm:ss");cell23.setCellValue(time);// 生成一张表(IO流) 07版本就是使用xlsx结尾!FileOutputStream fileOutputStream = new FileOutputStream(PATH + "阿巴阿巴你学习了吗.xlsx");// 输出workbook.write(fileOutputStream);// 关闭流fileOutputStream.close();System.out.println("Execl生成完毕");

注意对象的一个区别,文件后缀!

数据批量导入!

二、大文件写HSSF

缺点:最多只能处理65536行,否则会抛出异常

java.lang.IllegalArgumentException: Invalid row number (65536) outside allowable range (0..65535)

优点:过程中写入缓存,不操作磁盘,最后一次性写入磁盘,速度快

03.xls

    @Testpublic void testWriteBigdata03() throws IOException {// 时间long begin = System.currentTimeMillis();// 1.创建一个工作簿(对象)Workbook workbook = new HSSFWorkbook();// 2.创建一个工作表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 outputStream = new FileOutputStream(PATH + "Bigdata03.xls");long end = System.currentTimeMillis();workbook.write(outputStream);// 关闭流outputStream.close();System.out.println((double)(end-begin)/1000);}

数据批量导入!

三、大文件写XSSF

缺点:写数据时速度非常慢,非常耗内存,也会发生内存溢出(om),如100w条

优点:可以写较大的数据量,如20w条

07.xlsx

    @Testpublic void testWriteBigdata07() throws IOException {// 时间long begin = System.currentTimeMillis();// 1.创建一个工作簿(对象)Workbook workbook = new XSSFWorkbook();// 2.创建一个工作表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 outputStream = new FileOutputStream(PATH + "Bigdata07.xlsx");long end = System.currentTimeMillis();workbook.write(outputStream);// 关闭流outputStream.close();System.out.println((double)(end-begin)/1000);}

四、大文件写SXSSF

优点:可以写非常大的数据量,如100w条甚至更多条,写数据速度快,占用更少的内存

注意:

过程中会产生临时文件,需要清理临时文件

默认由100条记录被保存在内存中,如果超过这数量,则最前面的数据被写入临时文件

如果想自定义内存中数据的数量,可以使用 new SXSSFWorkbook(数量)

/*
代码与XSSF相同,只需要改变创建对象
由于会产生临时文件,我们需要在最后把临时文件删除,使用:
((SXSSFWorkbook) workbook).dispose();
*/@Testpublic void testWriteBigdata07_2() throws IOException {// 时间long begin = System.currentTimeMillis();// 1.创建一个工作簿(对象)Workbook workbook = new SXSSFWorkbook();// 2.创建一个工作表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 outputStream = new FileOutputStream(PATH + "Bigdata07.xlsx");long end = System.currentTimeMillis();workbook.write(outputStream);// 关闭流outputStream.close();// 清除临时文件((SXSSFWorkbook) workbook).dispose();System.out.println((double)(end-begin)/1000);}

SXSSFWorkbook-来自官方的解释:

实现”BigGridDemo“策略的流式XSSFWorkbook版本。这允许写入非常大的文件而不会耗尽内存,因为任何时候只有可配置的行部分被保存在内存中。

请注意,仍然可能会消耗大量内存,这些内存基于您正在使用的功能,例如合并区域,注释…仍然只存储在内存中,因此如果广泛使用,可能需要大量内存

再使用POI的时候,内存问题Jprofile!

POI-Excel写

一、03 | 07

二、读取不同的数据类型

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.joda.time.DateTime;
import org.junit.jupiter.api.Test;import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Date;@Testpublic void testCellType() throws IOException {// 获取文件流FileInputStream inputStream = new FileInputStream( PATH + "明细表.xls" );// 1.创建一个工作簿(对象):使用execl能操作的这边都可以操作Workbook workbook = new HSSFWorkbook(inputStream);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) { // 一定要先做非空判断CellType cellType = cell.getCellTypeEnum();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 = rowTitle.getPhysicalNumberOfCells();for(int cellNum = 0 ; cellNum < cellCount ; cellNum++){System.out.print("[" + (rowNum+1) + "-" + (cellNum+1) + "]");Cell cell = rowData.getCell(cellNum);// 匹配列的数据类型if(cell!=null) {// CellType cellType = cell.getCellTypeEnum();String cellValue = " ";if (cell != null) {CellType cellType = cell.getCellTypeEnum();switch (cellType) {case STRING:System.out.print("【String类型】");cellValue = cell.getStringCellValue();break;case _NONE:System.out.print("【_NONE类型】");cellValue = String.valueOf(cell.getStringCellValue());break;case FORMULA:System.out.print("【FORMULA类型】");break;case BLANK:System.out.print("【BLANK类型】");cellValue = String.valueOf(cell.getStringCellValue());break;case BOOLEAN:System.out.print("【BOOLEAN类型】");cellValue = String.valueOf(cell.getBooleanCellValue());break;case NUMERIC:System.out.print("【NUMERIC类型】");if(HSSFDateUtil.isCellDateFormatted(cell)){// 日期System.out.print("【日期】");Date date = cell.getDateCellValue();new DateTime(date).toString("yyyy-MM-dd");}else{// 如果不是日期格式,防止数字过长(科学计数法)System.out.print("【转换为字符串输出】");cell.setCellType(CellType.STRING);cellValue = cell.toString();}break;case ERROR: // 错误System.out.print("【ERROR类型】");break;}System.out.println(cellValue);}}}}inputStream.close();}}

需要注意类型转换问题

将代码提取成Java工具类:将inputStream变成参数

@Testpublic void testCellType(FileInputStream inputStream) throws IOException {// 获取文件流:直接传进来就可以// FileInputStream inputStream = new FileInputStream( PATH + "明细表.xls" );// 1.创建一个工作簿(对象):使用execl能操作的这边都可以操作Workbook workbook = new HSSFWorkbook(inputStream);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) { // 一定要先做非空判断CellType cellType = cell.getCellTypeEnum();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 = rowTitle.getPhysicalNumberOfCells();for(int cellNum = 0 ; cellNum < cellCount ; cellNum++){System.out.print("[" + (rowNum+1) + "-" + (cellNum+1) + "]");Cell cell = rowData.getCell(cellNum);// 匹配列的数据类型if(cell!=null) {// CellType cellType = cell.getCellTypeEnum();String cellValue = " ";if (cell != null) {CellType cellType = cell.getCellTypeEnum();switch (cellType) {case STRING:System.out.print("【String类型】");cellValue = cell.getStringCellValue();break;case _NONE:System.out.print("【_NONE类型】");cellValue = String.valueOf(cell.getStringCellValue());break;case FORMULA:System.out.print("【FORMULA类型】");break;case BLANK:System.out.print("【BLANK类型】");cellValue = String.valueOf(cell.getStringCellValue());break;case BOOLEAN:System.out.print("【BOOLEAN类型】");cellValue = String.valueOf(cell.getBooleanCellValue());break;case NUMERIC:System.out.print("【NUMERIC类型】");if(HSSFDateUtil.isCellDateFormatted(cell)){// 日期System.out.print("【日期】");Date date = cell.getDateCellValue();new DateTime(date).toString("yyyy-MM-dd");}else{// 如果不是日期格式,防止数字过长(科学计数法)System.out.print("【转换为字符串输出】");cell.setCellType(CellType.STRING);cellValue = cell.toString();}break;case ERROR: // 错误System.out.print("【ERROR类型】");break;}System.out.println(cellValue);}}}}inputStream.close();}}

三、计算公式

    @Testpublic void testFormula() throws Exception {FileInputStream inputStream = new FileInputStream(PATH + "公式.xls");Workbook workbook = new HSSFWorkbook(inputStream);Sheet sheet = workbook.getSheetAt(0);Row row = sheet.getRow(4);Cell cell = row.getCell(0);// 拿到计算公式 evalFormulaEvaluator FormulaEvaluator = new HSSFFormulaEvaluator((HSSFWorkbook)workbook);// 输出单元格的内容CellType cellType = cell.getCellTypeEnum();switch(cellType){case FORMULA: // 公式String formula = cell.getCellFormula();System.out.println(formula);// 计算CellValue evaluate = FormulaEvaluator.evaluate(cell);String cellValue = evaluate.formatAsString();System.out.println(cellValue);break;}}

EasyExcel操作

一、导入依赖

首先要去掉poi的依赖,因为它内置了该依赖

<dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>2.2.6</version>
</dependency>
<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.12</version><scope>provided</scope>
</dependency>
<dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.75</version>
</dependency>

二、写入测试

1、DemoData.java


2、测试写入数据


最终的结果:

三、读取测试

http://www.yuque.com/easyexcel/doc/read

EasyExcel总结笔记

读excel

step 01 导入依赖
  • pom文件中导入依赖

  • <dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>2.2.6</version>
    </dependency>
    <dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.12</version><scope>provided</scope>
    </dependency>
    <dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.75</version>
    </dependency>
    
step 02 写实体类
  • java \ com \ ding \ 实体类名 \ DemoData

  • 创建对象 ==> 创建实体层

  • @Data
    public class DemoData {private String string;private Date date;private Double doubleData;
    }
    
step 03 写测试类

写excel

step 01 导入依赖
  • pom文件中导入依赖

  • <dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>2.2.6</version>
    </dependency>
    <dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.12</version><scope>provided</scope>
    </dependency>
    <dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.75</version>
    </dependency>
    
step 02 写实体类
  • java \ com \ ding \ 实体类名 \ DemoData

  • 创建对象 ==> 创建实体层

  • @Data
    public class DemoData {private String string;private Date date;private Double doubleData;
    }
    
step 03 写测试类
  • 业务逻辑层 ==> 写一个测试类

  • 通用数据生成

  • public class EasyTest{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;}// 写值代码/*** 最简单的写* <p>1. 创建excel对应的实体对象 参照{@link DemoData}* <p>2. 直接写即可*/@Testpublic void simpleWrite() {// 写法1String fileName = "生成测试文件.xlsx";// 这里 需要指定写用哪个class去写,然后写到第一个sheet,名字为模板 然后文件流会自动关闭EasyExcel.write(fileName, DemoData.class).sheet("模板").doWrite(data());}}
    
  • 方法返回一个list,我们要根据list写值,写入excel

  • EasyExcel.write() 方法

    • wirte ( fileName,格式类 )

    • sheet ( 表名 )

    • doWrite ( 数据 )

    • EasyExcel.write(fileName, DemoData.class).sheet("模板").doWrite(data());
      

附录

一些问题

01 关于POI 操作 Excel 中 HSSFCell.CELL_TYPE_STRING 等无定义解决方法

一、错误原因:jar包版本更新,官方改动;

二、解决方案:导入CellType包import org.apache.poi.ss.usermodel.CellType;使用CellType.STRING代替HSSFCell.CELL_TYPE_STRING

三、旧版代码:

/*** excel值处理* @param hssfCell* @return*/public static Object getXSSFValue(XSSFCell hssfCell) {if(hssfCell.getCellType() == XSSFCell.CELL_TYPE_NUMERIC) {return hssfCell.getNumericCellValue();    //数字}else if(hssfCell.getCellType() == XSSFCell.CELL_TYPE_BOOLEAN) {return hssfCell.getBooleanCellValue();    //boolean}else if(hssfCell.getCellType() == XSSFCell.CELL_TYPE_ERROR){return hssfCell.getErrorCellValue();      //故障}else if(hssfCell.getCellType() == XSSFCell.CELL_TYPE_FORMULA){return hssfCell.getCellFormula();         //公式}else if(hssfCell.getCellType() == XSSFCell.CELL_TYPE_BLANK) {return "";                                //空值}else {return hssfCell.getStringCellValue();     //字符串}}/*** excel值处理* @param hssfCell* @return*/public static Object getValue(Cell hssfCell) {if(hssfCell.getCellType()==XSSFCell.CELL_TYPE_NUMERIC) {return hssfCell.getNumericCellValue();   //数字 }else if(hssfCell.getCellType()==XSSFCell.CELL_TYPE_BOOLEAN) {return hssfCell.getBooleanCellValue();   //boolean}else if(hssfCell.getCellType()==XSSFCell.CELL_TYPE_ERROR){return hssfCell.getErrorCellValue();     //故障}else if(hssfCell.getCellType()==XSSFCell.CELL_TYPE_FORMULA){return hssfCell.getCellFormula();        //公式}else if(hssfCell.getCellType() == XSSFCell.CELL_TYPE_BLANK) {return ""; 	                             //空值}else {return hssfCell.getStringCellValue();    //字符串}}

四、新版代码:

/*** excel值处理** @param hssfCell* @return*/public static Object getXSSFValue(XSSFCell hssfCell) {Object result = null;CellType cellType = hssfCell.getCellType();switch (hssfCell.getCellType()) {case NUMERIC: //数字result = hssfCell.getNumericCellValue();break;case BOOLEAN: //Booleanresult = hssfCell.getBooleanCellValue();break;case ERROR: //故障result = hssfCell.getErrorCellValue();break;case FORMULA: //公式result = hssfCell.getCellFormula();break;case BLANK: //空值result = "";break;default: //字符串result = hssfCell.getStringCellValue();}return result;}/*** excel值处理** @param hssfCell* @return*/public static Object getValue(Cell hssfCell) {Object result = null;switch (hssfCell.getCellType()) {case NUMERIC: //数字result = hssfCell.getNumericCellValue();break;case BOOLEAN: //Booleanresult = hssfCell.getBooleanCellValue();break;case ERROR: //故障result = hssfCell.getErrorCellValue();break;case FORMULA: //公式result = hssfCell.getCellFormula();break;case BLANK: //空值result = "";break;default: //字符串result = hssfCell.getStringCellValue();}return result;}

固定套路:

1、写入,固定类格式进行写入

2、读取,根据监听器设置的规则进行读取

了解,面向对象的思想,面向接口编程

理解使用测试API

官方文档的API进行自己的测试并进行总结

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

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

相关文章

93. 复原 IP 地址 - 力扣(LeetCode)

题目描述 有效 IP 地址 正好由四个整数&#xff08;每个整数位于 0 到 255 之间组成&#xff0c;且不能含有前导 0&#xff09;&#xff0c;整数之间用 ‘.’ 分隔。 例如&#xff1a;“0.1.2.201” 和 “192.168.1.1” 是 有效 IP 地址&#xff0c;但是 “0.011.255.245”、“…

matlab appdesigner系列-常用16-状态按钮

状态按钮&#xff0c;有两个状态&#xff0c;按下状态&#xff0c;返回值为1或true&#xff1b;未按下状态&#xff0c;返回值为0或false 示例&#xff1a;设置一状态按钮&#xff0c;用文本记录其状态 操作步骤&#xff1a; 1&#xff09;将状态按钮、文本区域拖拽到画布上…

LeetCode 热题 100 | 哈希

目录 1 基础知识 1.1 定义哈希表 1.2 遍历哈希表 1.3 查找某一个键 1.4 插入键值对 1.5 获取键值对的值 1.6 搜索功能 2 三道题 2.1 1. 两数之和 2.2 49. 字母异位词分组 2.3 128. 最长连续序列 菜鸟做题第一周&#xff0c;语言是 C 1 基础知识 1.1 定…

对网站进行打点(不要有主动扫描行为)

什么是打点&#xff1f; 简单来说就是获取一个演习方服务器的控制权限。 目的&#xff1a; 1. 上传一个一句话木马 2. 挖到命令执行 3. 挖到反序列化漏洞 4. 钓鱼 假设对“千峰”网站进行打点&#xff1a; 1. 利用平台 1. 利用各类平台&#xff1a; 天眼查-商业查询平…

Unity SnapScrollRect 滚动 匹配 列表 整页

展示效果 原理: 当停止滑动时 判断Contet的horizontalNormalizedPosition 与子Item的缓存值 相减,并得到最小值&#xff0c;然后将Content horizontalNormalizedPosition滚动过去 使用方式&#xff1a; 直接将脚本挂到ScrollRect上 注意&#xff1a;在创建Content子物体时…

Mysql运维篇(二) 主从复制

一路走来,所有遇到的人,帮助过我的、伤害过我的都是朋友,没有一个是敌人,如有侵权请留言,我及时删除。 一、主从复制的原理 主库会生成一个I/O操作线程进去写的的操作,而从库则生成两个线程,其一是I/O读取线程,其二是一个SQL线程。 1、主库将数据的操作记录到一个二进…

C++的流库

1.流的概念 “流”&#xff0c;即“流动”的意思&#xff0c;是物质从一处向另一处流动的过程。在计算机这边通常是指对一种有序连续且具有方向性的数据的抽象描述。 C 中的流一般指两个过程的统一&#xff1a; 信息从外部输入设备&#xff08;键盘&#xff09;向计算机内部…

【数据结构与算法】之字符串系列-20240121

这里写目录标题 一、344. 反转字符串二、125. 验证回文串三、205. 同构字符串四、242. 有效的字母异位词五、290. 单词规律 一、344. 反转字符串 简单 编写一个函数&#xff0c;其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。 不要给另外的数组分配额…

k8s集群加入一个master2--kubeadm方式

已经有一个集群&#xff1a; 192.168.206.138 master 192.168.206.136 k8s-node1 192.168.206.137 k8s-node2 kubectl get nodes -o wide 新加入一个master2节点 192.168.206.139 master2 一、初始化系统参数 139 master2 上 #在136、137、138上添加hosts“” echo "…

贪心算法笔记

贪心 1.序列问题1.1摆动序列1.2单调递增的数字 2.多维度权衡2.1分发糖果2.2根据身高重构队列 3.区间问题3.1跳跃问题3.2跳跃问题 II3.3用最小数量的箭引爆气球3.4无重叠区间3.5划分字母区间3.6合并区间 4.其他4.1最大子数组和4.2加油站4.3监控二叉树 正如这个算法的名字一样&am…

【办公类-19-02】20240122图书EXCEL插入列并删除空行

作品展示 背景需求 上次23个班级班主任统计图书&#xff0c;写在EXCEL内 【办公类-19-01】20240108图书统计登记表制作&#xff08;23个班级&#xff09;EXCEL复制表格并合并表格-CSDN博客文章浏览阅读693次&#xff0c;点赞12次&#xff0c;收藏7次。【办公类-19-01】202401…

Unity 编辑器篇|(十三)自定义属性绘制器(PropertyDrawer ,PropertyAttribute) (全面总结 | 建议收藏)

目录 1. 前言2. PropertyDrawer2.1 参数总览2.2 两种用途2.3 注意事项2.4 代码样例 3. PropertyDrawer与PropertyAttribute结合使用 1. 前言 在Unity中&#xff0c;PropertyDrawer和PropertyAttribute是两个重要的工具&#xff0c;它们主要用于自定义属性的显示和行为。Proper…

【JS逆向学习】国家加密系列-SM算法实例

SM系列 1、国家加密算法介绍 事实上从 2010 年开始&#xff0c;我国国家密码管理局就已经开始陆续发布了一系列国产加密算法&#xff0c;其中SM1、SM4、SM7、祖冲之密码&#xff08;ZUC&#xff09;是对称算法&#xff1b;SM2、SM9是非对称算法&#xff1b;SM3是哈希算法。目…

Django框架二

一、模型层及ORM 1.模型层定义 负责跟数据库之间进行通信 2.Django配置mysql 安装mysqlclient&#xff0c;mysqlclient版本最好在13.13以上 pip3 install mysqlclient DATABASES {default: {ENGINE: django.db.backends.mysql,NAME: "mysite1",USER:root,PASSWO…

pip安装之后还是无法使用问题处理

最近由于需要使用到Python 相关功能&#xff0c; 记录下一些入门小技巧 1 python 下载安装 在window10 环境下载免安装版本&#xff0c; 并解压 安装包下载地址&#xff1a; https://www.python.org/ftp/python/3.12.1/python-3.12.1-embed-amd64.zip 2. 安装pip, 由于是内嵌…

【立创EDA-PCB设计基础】5.布线设计规则设置

前言&#xff1a;本文详解布线前的设计规则设置。经过本专栏中的【立创EDA-PCB设计基础】前几节已经完成了布局&#xff0c;接下来开始进行布线&#xff0c;在布线之前&#xff0c;要设置设计规则。 目录 1.间距设置 1.1 安全间距设置 1.2 其它间距设置 2.物理设置 2.1 导…

力扣hot100 合并两个有序链表 递归 双指针

Problem: 21. 合并两个有序链表 文章目录 &#x1f496; 递归思路 &#x1f496; 双指针 &#x1f496; 递归 思路 &#x1f468;‍&#x1f3eb; 参考地址 n , m n,m n,m 分别为 list1 和 list2 的元素个数 ⏰ 时间复杂度: O ( n m ) O(nm) O(nm) &#x1f30e; 空间复杂…

是谁说网工这行是小众行业?我帮你搜了搜……

有人说网工这行是个小众行业&#xff0c;很多朋友在喊岗位不够多&#xff0c;我帮你搜了搜&#xff0c;其实招聘岗位的需求真的很多&#xff1a; 可能你换着搜索下关键词&#xff0c;善用不同类型的渠道&#xff0c;你会有新的惊喜。 能达到这要求的&#xff0c;这位朋友&#…

线程池--JAVA

虽然线程是轻量级进程&#xff0c;但是如果当创建和销毁的的频率非常之高&#xff0c;那么它也就会消耗很多的资源。 而线程池就是用来优化线程频繁创建和销毁的场景&#xff0c;减少线程创建、销毁的频率。 ExecutorService JAVA标准库为我们实现了线程池&#xff0c;Execu…

华而有实,维乐Prevail Glide带你领略风景线,成为风景线~

大家都知道呢&#xff01;骑行&#xff0c;不仅是一种运动&#xff0c;更是一种生活态度。在骑行装备的世界里&#xff0c;一个好的坐垫对于骑行的舒适度和安全性至关重要。那今天&#xff0c;我要为大家推荐一款备受赞誉的坐垫——维乐坐垫美学系列-Prevail Glide。    为…