当前位置: 首页 > news >正文

数据导入导出(EasyExcel)框架入门指南

写在前面
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站


文章目录

  • EasyExcel 框架
    • 概述
    • 依赖
    • API
      • Excel 实体类注解
      • 写 Excel
        • 概念介绍
        • 写 Excel 通用参数
        • WriteWorkbook
        • WriteSheet
        • WriteTable
  • 代码示例
    • 创建 Excel 文件
      • (1)配置实体类
      • (2)Excel 文件的生成和下载
    • 模板打印
      • (1)定义模板
      • (2)填充模板并下载 Excel 模板文件
    • 解析 Excel 文件
      • (1)配置实体类
      • (2)解析 Excel 文件
  • 拓展
    • csv 读写的支持

EasyExcel 框架

本文仅作为快速入门指南,深入学习详见官方文档

概述

Java 解析、生成 Excel 比较有名的框架有Apache poi、jxl,但它们都存在一些严重的问题,如代码编写繁琐且重复,极其耗费内存。EasyExcel 是一个基于 Java 的简单、省内存的读写 Excel 的开源项目。在尽可能节约内存的情况下支持读写百万级数据的 Excel。

EasyExcel:阿里巴巴开源的操作 Excel 的框架,底层封装的 POI,可以大大减少占用内存的主要原因是在解析 Excel 时,没有将文件数据一次性全部加载到内存中,而是从磁盘上一行行读取数据,逐个解析。

下图是 easyExcel 和 POI 在解析 Excel 时的对比图:

在这里插入图片描述


easyExcel 采用一行一行的解析模式,并将一行的解析结果以观察者的模式通知处理(AnalysisEventListener)。

在这里插入图片描述

  • 在实体类上配置注解(适配 Excel 中的标题)
  • 调用 EasyExcel 的工具类方法,完成文件的上传或者下载

依赖

		<dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.1.1</version></dependency>

API

Excel 实体类注解

  • @ExcelIgnoreUnannotated:标注在实体类上,作用是只使用标注了 @ExcelProperty 注解的字段参与 excel 读写。默认是不管加不加 ExcelProperty 的注解,所有字段都会参与读写

  • @ExcelProperty:标注在实体类属性上,用于 excel 的列和实体类属性的匹配

    参数如下:

    名称默认值描述
    value用于匹配excel中的头,必须全匹配,如果有多行头,会匹配最后一行头
    orderInteger.MAX_VALUE优先级高于value,会根据order的顺序来匹配实体和 excel 中数据的顺序
    index-1优先级高于valueorder,会根据index直接指定到excel中具体的哪一列
    converter自动选择指定当前字段用什么转换器,默认会自动选择。写的情况下只要实现com.alibaba.excel.converters.Converter#convertToExcelData(com.alibaba.excel.converters.WriteConverterContext<T>) 方法即可
  • @ExcelIgnore:标注在实体类属性上,默认所有字段都会和 excel 去匹配,加了这个注解会忽略该字段

  • @DateTimeFormat:标注在实体类属性上,日期转换

    参数如下:

    名称默认值描述
    value参照java.text.SimpleDateFormat书写即可
    use1904windowing自动选择excel中时间是存储1900年起的一个双精度浮点数,但是有时候默认开始日期是1904,所以设置这个值改成默认1904年开始
  • @NumberFormat:标注在实体类属性上,数字转换

    参数如下:

    名称默认值描述
    value参照java.text.DecimalFormat书写即可
    roundingModeRoundingMode.HALF_UP格式化的时候设置舍入模式

写 Excel

概念介绍
  • WriteWorkbook :可以理解成一个 excel 文件
  • WriteSheet :理解成一个excel 文件里面的一个表单
  • WriteTable : 一个表单里面如果有多个实际用的表格,则可以用 WriteTablejava

写 Excel 通用参数

WriteWorkbook,WriteSheet ,WriteTable 都会有的参数,如果为空,默认使用上级。

名称默认值描述
converter默认加载了很多转换器,这里可以加入不支持的字段
writeHandler写的处理器。可以实现WorkbookWriteHandler,SheetWriteHandler,RowWriteHandler,CellWriteHandler,在写入excel的不同阶段会调用
relativeHeadRowIndex0写入到excel和上面空开几行
headclazz二选一。读取文件头对应的列表,会根据列表匹配数据,建议使用class
clazzhead二选一。读取文件的头对应的class,也可以使用注解。如果两个都不指定,则会读取全部数据
autoTrimtrue会对头、读取数据等进行自动trim
use1904windowingfalseexcel中时间是存储1900年起的一个双精度浮点数,但是有时候默认开始日期是1904,所以设置这个值改成默认1904年开始
useScientificFormatfalse数字转文本的时候在较大的数值的是否是否采用科学计数法
needHeadtrue是否需要写入头到excel
useDefaultStyletrue是否使用默认的样式
automaticMergeHeadtrue自动合并头,头中相同的字段上下左右都会去尝试匹配
excludeColumnIndexes需要排除对象中的index的数据
excludeColumnFieldNames需要排除对象中的字段的数据
includeColumnIndexes只要导出对象中的index的数据
includeColumnFieldNames只要导出对象中的字段的数据

WriteWorkbook

设置方法如下(找不到参数的看下通用参数里面是否存在):

EasyExcel.write(fileName, DemoData.class)// 在 write 方法之后, 在 sheet方法之前都是设置 WriteWorkbook 的参数.sheet("模板").doWrite(() -> {// 分页查询数据return data();});

WriteWorkbook 方法:

public static ExcelWriterBuilder write()
public static ExcelWriterBuilder write(File file)
public static ExcelWriterBuilder write(String pathName)
public static ExcelWriterBuilder write(String pathName, Class head)
public static ExcelWriterBuilder write(OutputStream outputStream)
public static ExcelWriterBuilder write(OutputStream outputStream, Class head)
// 参数说明:
// 		file		创建的excel文件路径,路径需包含文件名
// 		pathName	创建的excel文件路径,路径需包含文件名
// 		outputStream	创建的excel文件的输出流,路径需包含文件名
// 		head		excel文件的行头实体类(标题栏)

WriteWorkbook 参数:

名称默认值描述
excelType当前excel的类型,支持XLS、XLSX、CSV
outputStreamfile二选一。写入文件的流
fileoutputStream二选一。写入的文件
templateInputStream模板的文件流
templateFile模板文件
charsetCharset#defaultCharset只有csv文件有用,写入文件的时候使用的编码
autoCloseStreamtrue自动关闭写入的流。
password读取文件的密码
inMemoryfalse是否在内存处理,默认会生成临时文件以节约内存。内存模式效率会更好,但是容易OOM
writeExcelOnExceptionfalse写入过程中抛出异常了,是否尝试把数据写入到excel

WriteSheet
  • 设置方法如下(找不到参数的看下通用参数里面是否存在)

    EasyExcel.write(fileName, DemoData.class).sheet("模板")// 在 sheet 方法之后, 在 doWrite方法之前都是设置WriteSheet的参数.doWrite(() -> {// 分页查询数据return data();});
    

    参数说明:

    名称默认值描述
    sheetNo0需要写入的编码
    sheetName需要些的Sheet名称,默认同sheetNo

WriteTable
  • 设置方法如下(找不到参数的看下通用参数里面是否存在)

    EasyExcel.write(fileName, DemoData.class).sheet("模板").table()// 在 table 方法之后, 在 doWrite方法之前都是设置WriteTable的参数.doWrite(() -> {// 分页查询数据return data();});
    

    参数说明:

    名称默认值描述
    tableNo0需要写入的编码

代码示例

创建 Excel 文件

(1)配置实体类

在 EasyExcel 中,通过 java 代码生成或者解析 Excel 文件很简单。不需要创建繁琐的表头

  • 创建数据行的实体类 : ContractProductVo

  • 在实体类上通过注解配置 :标题,行高,列宽等数据

    • @ExcelProperty:在创建Excel的时候,自动的读取实体类中的注解配置,生成表头
  • 示例代码如下

    import com.alibaba.excel.annotation.ExcelProperty;
    import com.alibaba.excel.annotation.format.DateTimeFormat;
    import com.alibaba.excel.annotation.write.style.ColumnWidth;
    import com.alibaba.excel.annotation.write.style.ContentRowHeight;
    import com.alibaba.excel.annotation.write.style.HeadRowHeight;
    import lombok.Data;
    import java.util.Date;/*** Excel 实体类*/
    @Data
    @ContentRowHeight(20)  //数据行高数
    @HeadRowHeight(20)     //表头高度
    @ColumnWidth(15)       //列宽
    public class UserExcelVo {@ExcelProperty("用户名")private String username;@ExcelProperty("密码")private String password;@ExcelProperty("电话")private String phone;@ExcelProperty("创建时间")@DateTimeFormat("yyyy-MM-dd")private Date createTime;
    }
    

(2)Excel 文件的生成和下载

  • 在 java 代码中通过 EasyExcel 工具类完成 excel 文件的生成和下载

  • 示例代码如下

    	/*** 使用 EasyExcel完成 excel 的生成和下载*  1、数据查询*  2、设置下载信息*  3、调用EasyExcel的工具类完成生成下载*/@RequestMapping("/printEasyExcel")public void printEasyExcel(String inputDate) throws IOException {//1、数据查询List<ContractProductVo> list = contractService.findByShipTime(inputDate+"%");//2、设置下载信息response.setContentType("application/vnd.ms-excel"); //下载excelresponse.setCharacterEncoding("utf-8");String fileName = URLEncoder.encode("出货表", "UTF-8");response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");//3、调用EasyExcel的工具类完成生成下载EasyExcel.write(response.getOutputStream()).head(ContractProductVo.class) //设置表头.sheet("test127") //指定页名称.doWrite(list); //设置数据}
    

模板打印

对于复杂样式的 Excel 文件创建,EasyExcel 支持模板打印。以一个 Excel 文件作为模板,自动的进行数据的拓展和填充。

  • 定义模板 ( 配置好了所有的样式 )
  • 配置实体类(表头)
  • java代码填充模板并下载 Excel

(1)定义模板

  • 在 easyExcel 中,支持两个模板语言
  • 语法:{map中的key}
    • 传入一个 map 集合:往往是用于处理非list集合的数据
  • 语法:{.对象中的属性名}
    • 传入一个 list 集合,会自动的循环 list 集合构造数据列表

在这里插入图片描述


(2)填充模板并下载 Excel 模板文件

	/*** 模板打印**/@RequestMapping("/printTemplate")public void printTemplate(String inputDate) throws IOException {//1.准备数据List<ContractProductVo> list = contractService.findByShipTime(inputDate+"%");Map map = new HashMap<>();inputDate = inputDate.replaceAll("-0","-").replaceAll("-","年");map.put("time",inputDate);map.put("title1","客户名称");//2.设置下载信息response.setContentType("application/vnd.ms-excel"); //下载excelresponse.setCharacterEncoding("utf-8");String fileName = URLEncoder.encode("出货表", "UTF-8");response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");//3.加载excel模板String path = session.getServletContext().getRealPath("/")+"/make/tOUTPRODUCT.xlsx";//4.创建EasyExcel的excelWtire对象( 用于数据填充)ExcelWriter excelWriter = EasyExcel.write(response.getOutputStream()).head(ContractProductVo.class) //设置表头.withTemplate(path) //加载模板.build();//获取sheet对象WriteSheet sheet = EasyExcel.writerSheet().build();//5.调用方法完成填充map数据excelWriter.fill(map,sheet);//6.调用方法完成填充list数据excelWriter.fill(list,sheet);//7.属性资源,完成下载excelWriter.finish(); //下载excel文件,释放内存资源}

解析 Excel 文件

(1)配置实体类

创建实体类对象(用于解析封装对象),配置表头注解,EasyExcel 自动的根据注解配置获取文件中对应行的内容

  • @ExcelIgnoreUnannotated:忽略默认表头配置
  • @ExcelPropertym:配置表头
import cn.itcast.domain.BaseEntity;
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;import java.io.Serializable;
import java.util.List;/*** 合同下货物的实体类*  通过EasyExcel完成文件解析,在实体类上通过注解配置表头*  如果实体类中的属性,未配置@ExcelProperty*      默认按照属性的编写顺序,从excel中获取数据*      默认情况下,为配置注解的属性会影响数据封装*  在类上配置一个注解:忽略未配置注解的属性*/
@ExcelIgnoreUnannotated
@Data
public class ContractProduct extends BaseEntity implements Serializable {private String id;@ExcelProperty("货号")private String productNo;		//货号private String productImage;	//图片路径@ExcelProperty("货物描述")private String productDesc;		//货描@ExcelProperty("装率")private String loadingRate;		//报运:装率    1/3@ExcelProperty("箱数")private Integer boxNum;			//报运:箱数    100@ExcelProperty("包装单位")private String packingUnit;		//包装单位:PCS/SETS   支/箱@ExcelProperty("数量")private Integer cnumber;		//数量                            300private Integer outNumber;		//报运:出货数量            200private Integer finished;		//报运:是否完成		no@ExcelProperty("要求")private String productRequest;	//要求@ExcelProperty("单价")private Double price;			//单价private Double amount;			//总金额,冗余private Integer orderNo;		//排序号private String contractId;      //合同号@ExcelProperty("生产厂家")private String factoryName;		//厂家名称,冗余字段private String factoryId;private List<ExtCproduct> extCproducts ;	//货物和附件,一对多
}

(2)解析 Excel 文件

修改 ContractProductController 对象,完成 EasyExcel 的文件批量上传

	/*** 通过 EasyExcel 完成文件上传解析,批量货物保存*  参数:购销合同id*  参数:上传的excel文件对象*/@RequestMapping("/import")public String importExcel(String contractId, MultipartFile file) throws Exception {List<ContractProduct> list = EasyExcel.read(file.getInputStream()).head(ContractProduct.class) //设置表头,将数据转化为目标对象.sheet(0) //读取第一页数据.doReadSync(); //解析excel,获取所有的数据for (ContractProduct contractProduct : list) {System.out.println(contractProduct);contractProduct.setContractId(contractId);contractProduct.setCompanyId(getLoginCompanyId());contractProduct.setCompanyName(getLoginCompanyName());}contractProductService.saveAll(list);return  "redirect:/cargo/contractProduct/list.do?contractId="+contractId;}

拓展

csv 读写的支持

在3.0.0-beta1版本开始支持,读的时候会自动判断。写的时候指定 excelType 就行。

EasyExcel.write(fileName, DemoData.class)// 指定导出类型为csv.excelType(ExcelTypeEnum.CSV).sheet("模板").doWrite(() -> {// 分页查询数据return data();});

相关文章:

数据导入导出(EasyExcel)框架入门指南

写在前面 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站 文章目录 EasyExcel 框架概述依赖APIExcel 实体类注解写 Excel概念介绍写 Excel 通用参数WriteWorkbookWriteSheetWriteTable 代码…...

Ubuntu如何实现每天定时关机

要在Ubuntu中实现每天定时关机&#xff0c;你可以使用cron来安排定时任务。以下是具体的步骤&#xff1a; 步骤 1: 创建脚本 打开终端。使用文本编辑器创建一个新的文件。例如&#xff1a; nano ~/shutdown_script.sh 步骤 2: 编写脚本 在编辑器中输入以下内容&#xff1a…...

【MySQL进阶】事务、存储引擎、索引、SQL优化、锁

一、事务 1.概念 事务是一组操作的集合&#xff0c;它是一个不可分割的工作单位&#xff0c;事务会把所有的操作作为一个整体一起向 系统提交或撤销操作请求&#xff0c;即这些操作要么同时成功&#xff0c;要么同时失败。 例子&#xff1a;转账&#xff0c;要求扣钱和进账…...

BeanDefinitionOverrideException产生原因及解决方案

BeanDefinitionOverrideException 是 Spring 框架中与依赖注入&#xff08;Dependency Injection&#xff09;相关的异常。它通常在 Spring 应用程序启动时抛出&#xff0c;当 Spring 在加载应用程序上下文时&#xff0c;检测到有多个相同名称的 Bean 定义被加载&#xff0c;并…...

配置Prettier+Vscode setting提高前端开发效率

前言 大家好&#xff0c;上一篇一文读懂 系列的文章中我们介绍了前端的代码格式化校验工具ESLient。代码格式是进行自动校验了&#xff0c;但你还要一个个的微调&#xff0c;很麻烦不是吗&#xff1f; 本文介绍和ESLient配合使用的Prettier实现编译器自动将代码格式化。 同时也…...

系统架构师计算题(1)——计算机系统基础知识(上)

持续刷题,持续总结,持续更新! 目录 1. 文件系统 题型1:多级索引 2. 存储管理 题型1:页式存储 题型2:段式存储 题型3:段页式存储 3. 磁盘读取 题型1:访问耗时 4. RAID 题型1:计算容量 1. 文件系统 文件在系统中的存储结构有如下几种: (1) 连续结构。 连续结构…...

2024/8/18周报

文章目录 摘要Abstract蚁群算法背景基本步骤应用TSP问题蚁群算法具体实现 遗传算法基本原理主要步骤遗传算法的主要组件遗传算法的应用遗传算法的优点遗传算法的局限性示例代码 多目标优化算法多目标优化的基本概念多目标优化算法的分类NSGA-II 算法示例 总结 摘要 本周对项目…...

端点安全新纪元:EDR与XDR技术的融合应用

在数字时代&#xff0c;随着网络威胁的日益复杂化和多样化&#xff0c;端点安全成为了企业组织不可或缺的重要防线。传统的防病毒软件和防火墙等安全解决方案已难以满足当前的安全需求&#xff0c;而EDR&#xff08;端点检测与响应&#xff09;和XDR&#xff08;扩展检测与响应…...

机器学习:多元线性回归模型

目录 前言 一、讲在前面 1.多元_血压.csv&#xff1a; 2.完整代码&#xff1a; 3.运行结果&#xff1a; 二、实现步骤 1.导入库 2.导入数据 3.绘制散点图&#xff08;这步可以省略&#xff09; ​编辑 4.求特征和标签的相关系数 5.建立并训练线性回归模型 6.检验模…...

树莓派5环境配置笔记 新建虚拟python环境—安装第三方库—配置Thonny解释器

树莓派5虚拟环境配及第三方库的安装&#x1f680; 在完成了树莓派的系统下载和各项基础配置之后进入到了&#xff0c;传感器开发部分&#xff0c;在测试传感器开发之前我打算先安装一下自己需要的库&#xff0c;但是在我直接在系统的根目录下运行pip命令的时候总会报环境错误&a…...

浅谈Winform

一、Winform简介说明 C# 是一种面向对象的编程语言&#xff0c;由微软开发并作为.NET框架的主要编程语言。C# 设计时考虑了易用性&#xff0c;并且具有丰富的特性&#xff0c;如垃圾回收、异常处理、泛型、LINQ&#xff08;Language Integrated Query&#xff09;、异步编程等。…...

MySQL(二)——CRUD

文章目录 CRUD新增全列插入指定列插入插入查询结果 查询全列查询指定列查询查询字段为表达式表达式不包含字段表达式包含一个字段表达式包含多个字段 补充&#xff1a;别名去重查询排序条件查询 补充&#xff1a;运算符区间查询模糊查询NULL的查询 分页查询聚合查询聚合函数 分…...

presto高级用法(grouping、grouping sets)

目录 准备工作&#xff1a; 在hive中建表 在presto中计算 分解式 按照城市分组 统计人数 按照性别分组 统计人数 ​编辑 按照爱好分组 统计人数 ​编辑 按照城市和性别分组 统计人数 按照城市和爱好分组 统计人数 按照性别和爱好分组 统计人数 按照城市和性别还有…...

二十五年后,Microsoft终于移除了FAT32的32GB分区限制——一个从草稿到现实的故事

二十五年后&#xff0c;Microsoft终于移除了FAT32的32GB分区限制——一个从草稿到现实的故事 你可能不知道&#xff0c;FAT32文件系统的32GB分区限制是怎么来的。这个限制其实是1994年Windows前开发者Dave Plummer无心插柳的结果&#xff0c;也是"草台班子"式开发的…...

Java二十三种设计模式-命令模式(18/23)

命令模式&#xff1a;将请求封装为对象的策略 概要 本文全面探讨了命令模式&#xff0c;从基础概念到实现细节&#xff0c;再到使用场景、优缺点分析&#xff0c;以及与其他设计模式的比较&#xff0c;并提供了最佳实践和替代方案&#xff0c;旨在帮助读者深入理解命令模式并…...

Kafka系列之:Dead Letter Queue死信队列DLQ

Kafka系列之:Dead Letter Queue死信队列DLQ 一、死信队列二、参数errors.tolerance三、创建死信队列主题四、在启用安全性的情况下使用死信队列更多内容请阅读博主这篇博客: Kafka系列之:Kafka Connect深入探讨 - 错误处理和死信队列一、死信队列 死信队列(DLQ)仅适用于接…...

Fragment学习笔记

静态加载 <fragment android:name"com.example.serviceapplication.fragment.TestFragment"android:layout_width"match_parent"android:layout_height"wrap_content"app:layout_constraintStart_toStartOf"parent"app:layout_cons…...

NGINX 基础参数与功能

章节 1 NGINX 的源码安装 2 NGINX 核心配置详解 3 NGINX 之 location 匹配优先级 4 NGINX 基础参数与功能 目录 1 实现 Nginx 账户认证功能 1.1 创建htpasswd 认证文件 1.2 创建数据目录 1.3 指定认证文件路径 1.4 测试效果 2 定义重定向错误日志 2.1 指定错误日志访问路…...

css设置元素居中显示

CSS中实现居中显示可以通过不同的属性来实现&#xff0c;取决于你是要水平居中还是垂直居中&#xff0c;或者两者都要。以下是一些常用的居中方法&#xff1a; 1.水平居中 - 行内元素或文本 .center-text {text-align: center; } 2.水平居中 - 块级元素 .center-block {mar…...

js判断一个任意值为空包括数组和对象

在JavaScript中&#xff0c;判断一个变量是否为空可以考虑以下几种情况&#xff1a; 如果变量可能是null或undefined&#xff0c;可以直接判断。 对于数组&#xff0c;如果想要判断数组为空&#xff08;长度为0&#xff09;&#xff0c;可以检查其length属性。 对于对象&…...

EmguCV学习笔记 VB.Net和C# 下的OpenCv开发

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 笔者的博客网址&#xff1a;https://blog.csdn.net/uruseibest 本教程将分为VB.Net和C#两个版本分别进行发布。 教程VB.net版本请…...

“TCP粘包”不是TCP的问题!

前言 写RPC用了Netty。涉及到粘包拆包问题。想复习一下。发现网上博客多是概念模糊不清。没有触及本质或者没有讲清楚。 遂决定自己写一篇 “TCP粘包”是谁的问题&#xff1f; 首先我们要明确TCP是面向字节流的协议。也就是说我们在应用层想使用TCP来传输数据时&#xff0c;…...

Electron项目依赖管理:最佳实践与常见错误

问题一 问题描述: 输入命令 pnpm add electron 后&#xff0c; electron 包在执行 postinstall 脚本时&#xff0c;尝试从网络上下载 Electron 二进制文件&#xff0c;但由于网络问题&#xff08;如连接超时或代理设置问题&#xff09;&#xff0c;导致下载失败。 λ pnpm a…...

华为数通路由交换HCIP/HCNP

2017-2022年软考高级网络规划设计师真题解析视频&#xff01;软考复习一定要多做历年真题&#xff01; 2022年软考网络规划设计师真题解析_哔哩哔哩_bilibili 2024年5月软考网络工程师真题解析合集&#xff0c;考后估分版【综合知识案例分析】 2024年5月软考网络工程师真题解…...

搜索面试题

1、目前怎么构建样本的&#xff1f;如果排序中第5个被点了&#xff0c;前面的作为负样本&#xff0c;后面的不要怎么样&#xff1b;为什么不好&#xff0c;为什么好。 点击作为负样本&#xff0c;曝光未点击作为负样本&#xff1b; 可以这样理解。您提到的排序中第5个被点的对…...

WPF学习(8) --Windows API函数的使用

一、API函数的介绍 1.FindWindow函数 [DllImport("user32.dll", CharSet CharSet.Auto)]public static extern IntPtr FindWindow(string lpClassName, string lpWindowName); 功能: FindWindow函数用于根据窗口的类名和窗口名称查找窗口的句柄&#xff08;IntPtr…...

Linux系统-用户账号文件

文章目录 文件一&#xff08;passwd&#xff09; 文件二&#xff08;shadow&#xff09; 加密密码部分 举例理解 文件三&#xff08;gshadow&#xff09; 文件四&#xff08;group&#xff09; 文件五&#xff08;skel&#xff09; 文件六&#xff08;login.defs&#…...

docker配置国内镜像加速

docker配置国内镜像加速 由于国内使用docker拉取镜像时&#xff0c;会经常出现连接超时的网络问题&#xff0c;所以配置Docker 加速来使用国内 的镜像加速服务&#xff0c;以提高拉取 Docker 镜像的速度。 1、备份docker配置文件 cp /etc/docker/daemon.json /etc/docker/da…...

C语言实现排序之堆排序算法

一、堆排序算法 基本思想 堆排序是一种比较有效的排序方法&#xff0c;其基本思想是&#xff1a; 构建最大堆&#xff1a;首先将待排序的数组构建成一个最大堆&#xff0c;即对于每个非叶子节点&#xff0c;它的值都大于或等于其子节点的值。排序&#xff1a;然后将堆顶元素…...

【STM32 Blue Pill编程】-外部中断配置及使用

外部中断配置及使用 文章目录 外部中断配置及使用1、中断介绍2、STM32中的中断3、硬件准备及接线4、GPIO配置5、代码实现在本文中,我们将介绍如何使用 STM32Cube IDE 中的 HAL 库配置和处理外部中断。 我们将通过一个带有按钮和 LED 的示例来演示这一点。 读完本文后,您将能够…...

MySQL 安装与配置教程:单机、主从复制与集群模式

目录 MySQL 简介MySQL 安装MySQL 基础配置MySQL 主从复制配置MySQL 集群配置总结 1. MySQL 简介 MySQL 是一个广泛使用的关系型数据库管理系统&#xff0c;具有高性能、高可靠性和易用性等特点。它支持多种部署模式&#xff0c;包括单机模式、主从复制模式&#xff08;用于高…...

JavaEE 的相关知识点(一)

一、过滤器 过滤器&#xff08;Filter&#xff09;是一个用于对请求和响应进行预处理的组件。过滤器可以在 Java Servlet 规范中使用&#xff0c;通常用于执行一些通用的任务 1、过滤器的作用 过滤器是一种javaEE规范中定义的一种技术&#xff0c;可以让请求达到目标servlet之…...

使用Python实现深度学习模型:智能医疗影像识别与诊断

介绍 智能医疗影像识别与诊断是现代医疗技术的重要应用,通过深度学习模型,可以自动分析和识别医疗影像,提高诊断的准确性和效率。本文将介绍如何使用Python和深度学习技术来实现智能医疗影像识别与诊断。 环境准备 首先,我们需要安装一些必要的Python库: pip install …...

24.给定一个链表,实现一个算法交换每两个相邻节点并返回其头部。要求不能修改列表节点中的值,只能更改节点本身。

24. Swap Nodes in Pairs 题目 给定一个链表,交换每两个相邻节点并返回其头部。要求不能修改列表节点中的值,只能更改节点本身。 Example: Given 1->2->3->4, you should return the list as 2->1->4->3....

Python 通过UDP传输超过64k的信息

Python 通过UDP传输超过64k的信息 在网络编程中&#xff0c;UDP&#xff08;用户数据报协议&#xff09;是一种常用的传输协议。与TCP不同&#xff0c;UDP是无连接的&#xff0c;并且不保证数据包的顺序、完整性及交付。尽管如此&#xff0c;UDP因其较低的延迟和开销而被广泛应…...

微服务设计原则——高性能:批量

能批量就不要并发。 如果调用方需要调用我们接口多次才能进行一个完整的操作&#xff0c;那么这个接口设计就可能有问题。 比如获取数据的接口&#xff0c;如果仅仅提供getData(int id)接口&#xff0c;那么使用方如果要一次性获取 20 个数据&#xff0c;它就需要循环遍历调用…...

C:指针学习-指针变量—学习笔记

今日伊雷娜&#xff1a; 目录 前言&#xff1a; 1、字符指针变量 1.1 使用字符指针存放字符 1.2 使用字符指针变量存放字符串 2、数组指针变量 2.1 什么是数组指针变量&#xff1f; 2.2 数组指针变量初始化 2.3 关于数组指针类型的解析 3、函数指针变量 3.1 函数地址 …...

【MySQL 07】表的增删查改 (带思维导图)

文章目录 &#x1f308; 一、insert 添加数据⭐ 1. 单行数据 全列插入⭐ 2. 多行数据 指定列插入⭐ 3. 插入否则更新⭐4. 插入否则替换 &#x1f308; 二、select 查询数据⭐ 1. select 列&#x1f319; 1.1 全列查询&#x1f319; 1.2 指定列查询&#x1f319; 1.3 查询字段…...

快速上手Git

Git相关概念 Git是一个开源的分布式版本控制系统&#xff0c;由Linus Torvalds在2005年创建&#xff0c;用于有效、高速地处理从小到大的项目版本管理。它是由 Linux 之父 Linus Torvalds 开发的&#xff0c;并已经成为了现代软件开发领域中最流行的版本控制系统之一。 git的工…...

RTC时钟测试

1. 基础知识 Linux 的系统时间有时跟硬件时间是不同步的。 Linux时钟分为系统时钟(System Clock)和硬件(Real Time Clock&#xff0c;简称RTC)时钟。系统时钟是指当前Linux Kernel中的时钟&#xff0c;而硬件时钟则是主板上由电池供电的时钟&#xff0c;这个硬件时钟可以在BIO…...

大数据技术——实战项目:广告数仓(第六部分)报表数据导出至clickhouse

目录 第11章 报表数据导出 11.1 Clickhouse安装 11.2 Clickhouse建表 11.2.1 创建database 11.2.2 创建table 11.3 Hive数据导出至Clickhouse 第11章 报表数据导出 由于本项目最终要出的报表&#xff0c;要求具备交互功能&#xff0c;以及进行自助分析的能力&#xff0c;…...

Android studio模拟制作-简易的订餐交易小案例

一、最终呈现效果 订餐支付小案例效果 二、布局设计activity_main.xml <?xml version"1.0" encoding"utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android"http://schemas.android.com/apk/res/android"xml…...

消防隐患在线小程序的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;用户管理&#xff0c;消防隐患举报管理&#xff0c;消防隐患分类管理&#xff0c;统计分类管理&#xff0c;处理结果管理&#xff0c;系统管理 微信端账号功能包括&#xff1a;系统首页&#xff0c;我…...

【Vue3】路由Params传参

【Vue3】路由Params传参 背景简介开发环境开发步骤及源码总结 背景 随着年龄的增长&#xff0c;很多曾经烂熟于心的技术原理已被岁月摩擦得愈发模糊起来&#xff0c;技术出身的人总是很难放下一些执念&#xff0c;遂将这些知识整理成文&#xff0c;以纪念曾经努力学习奋斗的日…...

授权cleanmymac访问全部磁盘 Mac授权访问权限 cleanmymac缺少权限

CleanMyMac是Mac系统下的一款专业的苹果电脑清理软件&#xff0c;同时也是一款优秀的电脑系统管理软件。它能有效清理系统垃圾&#xff0c;快速释放磁盘内存&#xff0c;缓解卡顿现象&#xff0c;保障系统顺畅地运行。 全磁盘访问权限&#xff0c;就好比机场内进行的安全检查。…...

Ubuntu/18.04 LTS下编译 BoringSSL 库

1、准备一个 Ubuntu/18.04 LTS 系统的设备 2、安装软件 GIT、GCC、CMAKE、G、Golang:1.16 及以上版本 3、克隆仓库源 git clone https://boringssl.googlesource.com/boringssl cd boringssl 4、使用特定版本 git checkout 9fc1c33e9c21439ce5f87855a6591a9324e569fd 5、编…...

【stm32项目】多功能智能家居室内灯光控制系统设计与实现(完整工程资料源码)

多功能智能家居室内灯光控制系统设计与实现 目录&#xff1a; 目录&#xff1a; 前言&#xff1a; 一、项目背景与目标 二、国内外研究现状&#xff1a; 2.1 国内研究现状&#xff1a; 2.2 国外研究现状&#xff1a; 2.3 发展趋势 三、硬件电路设计 3.1 总体概述 3.2 硬件连接总…...

xss靶场详解

目录 1.第一题 2.第二题 3.第三题 4.第四题 5.第五题 6.第六题 7.第七题 8.第八题 1.第一题 在源码script标签里边&#xff0c;innerhtml是用于访问或修改 HTML 元素内的 HTML 内容的&#xff0c;这里是访问spaghet这个元素的&#xff0c;并通过括号里面的东西搜索当前…...

华为的流程管理

华为建设流程体系始于2000年&#xff0c;那时华为公司面临着快速扩张和全球化发展的挑战&#xff0c;意识到传统的管理模式已经无法满足业务发展的需求。为了提高公司的管理效率和竞争优势&#xff0c;华为决定启动流程体系的建设。在建设过程中&#xff0c;华为借鉴了业界最佳…...

操作系统Linux

1.Linux命令 ls&#xff1a;查看当前目录下所有目录和文件ps&#xff1a;查看所有正在运行的进程top&#xff1a;显示当前系统中占用资源最多的一些进程&#xff0c;shiftm按照内存查看大小netstat&#xff1a;查看端口的命令vi&#xff1a;查看文件的命令rm&#xff1a;删除文…...