Java常规代码实现合集


1.List查重复
通过使用HashSet的不可重复性来实现查重,时间复杂度为O(1)
具体实现 代码片

 // 假设已经将文件解析为 List<CpitalBudgetingLimitAmount>
 List<CpitalBudgetingLimitAmount> importCpitalBudgetingLimitAmountList = parseFile(file);

 // 检查 LeCode 是否重复
 Set<String> seenLeCodes = new HashSet<>();
 //存储重复LeCode
 Set<String> duplicateLeCodes = new HashSet<>();
 for (CpitalBudgetingLimitAmount item : importCpitalBudgetingLimitAmountList) {
     String leCode = item.getLeCode();
     //发现重复,存入duplicateLeCodes
     if (!seenLeCodes.add(leCode)) {
         duplicateLeCodes.add(leCode);//此处处理根据实际情况可以调整
     }
 }
 if (!duplicateLeCodes.isEmpty()) {
     // 处理重复 LeCode 的情况,例如抛出异常或记录日志
     throw new IllegalArgumentException("存在重复的 LeCode: " + duplicateLeCodes);
 }

2.FastExcel,高效的Java端Excel表格工具
官方文档链接:https://idev.cn/fastexcel/zh-CN/docs/read/read_hard
具体使用
2.1 springboot引入
2.1.1 引入fastExcel依赖包

  <dependency>
         <groupId>cn.idev.excel</groupId>
         <artifactId>fastexcel</artifactId>
         <version>1.0.0</version> <!-- 请确保使用最新版本 -->
   </dependency>

2.1.2 由于其有些功能还需依赖POI实现,因此加入POI依赖包

 <dependency>
         <groupId>org.apache.poi</groupId>
         <artifactId>poi</artifactId>
         <version>5.2.3</version> <!-- 使用最新版本 -->
     </dependency>
     <dependency>
         <groupId>org.apache.poi</groupId>
         <artifactId>poi-ooxml</artifactId>
         <version>5.2.3</version> <!-- 使用最新版本 -->
     </dependency>

2.2 创建实体类和监听器
2.2.1 创建实体类

package com.ruoyi.domain.dto;

import cn.idev.excel.annotation.ExcelProperty;
import com.ruoyi.common.annotation.Excel;
import com.ruoyi.common.core.domain.BaseEntity;
import lombok.Data;

@Data
public class matchingRulesFastExcelDto extends BaseEntity {
 private static final long serialVersionUID = 1L;

 @ExcelProperty("单据类型")
 private String OrderType;

 @ExcelProperty("业务类型区分")
 private String businessType;

 @ExcelProperty("原编码")
 private String businessTypes;

 @ExcelProperty("新编码")
 private String businessCode;

 @ExcelProperty("业务类型名称")
 private String bizCategoryName;
}

2.2.2 创建事件监听器

import cn.idev.excel.context.AnalysisContext;
import cn.idev.excel.event.AnalysisEventListener;

import java.util.ArrayList;
import java.util.List;
public class BaseExcelListener<T> extends AnalysisEventListener<T> {
 // 用于存储读取到的Excel数据对象列表
 private List<T> dataList = new ArrayList<>();
 @Override
 public void invoke(T t, AnalysisContext analysisContext) {
     // 每读取一行数据,就将其添加到dataList中
     dataList.add(t);
 }
 @Override
 public void doAfterAllAnalysed(AnalysisContext analysisContext) {
     // 当所有数据读取完成后,可以在这里进行一些后续操作,如打印读取到的数据数量
     System.out.println("读取完成,共读取了 " + dataList.size() + " 条数据");
 }
 // 提供一个方法用于获取存储数据的列表
 public List<T> getDataList() {
     return dataList;
 }
}

FastExcel 是依靠事件监听器实现 Excel 逐行读取文件的,如果没有这种逐行处理的机制和数据监听器,在处理大文件时可能会导致内存溢出。而事件监听器使得数据可以边读取边处理,例如,可以直接将数据写入数据库或者进行其他业务逻辑处理,避免了大量数据在内存中的堆积
2.3实现写入和读取功能
2.3.1 Excel写入功能

// Excel写入功能
@GetMapping("/download")
public void download(HttpServletResponse response) throws IOException {
   response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
   response.setCharacterEncoding("utf-8");
   String fileName = URLEncoder.encode("test", "UTF-8");
   response.setHeader("Content-disposition",
                      "attachment;filename*=utf-8''" + fileName + ".xlsx");
   // 写入数据
   FastExcel.write(response.getOutputStream(), User.class)
   .sheet("模板")
   .doWrite(buildData());
}
// 创建测试数据
private List<User> buildData() {
   // 创建 User 测试数据
   User user1 = new User();
   user1.setId(1);
   user1.setName("张三");
   user1.setAge(18);
   User user2 = new User();
   user2.setId(2);
   user2.setName("李四");
   user2.setAge(19);
   return List.of(user1, user2);
}

2.3.2 Excel读取功能

  // Excel读取功能,使用FastExcel功能,测试,并非正式
 @PostMapping("/upload")
 public void upload(HttpServletResponse response, MultipartFile file) throws IOException {
     try {
         System.out.println("开始读取");
         BaseExcelListener<matchingRulesFastExcelDto> baseExcelListener = new BaseExcelListener<>();
         FastExcel.read(file.getInputStream(), matchingRulesFastExcelDto.class,
                 baseExcelListener).sheet().doRead();
         // 得到读取数据
         List<matchingRulesFastExcelDto> dataList = baseExcelListener.getDataList();
         System.out.println(dataList);
         System.out.println("读取结束");
     } catch (IOException e) {

     }
 }

2.4 修改springboot文件大小配置

# Spring配置
spring:
# 资源信息
messages:
 # 国际化资源文件路径
 basename: i18n/messages
profiles:
 active: @profileActive@
# 文件上传
servlet:
 multipart:
   # 单个文件大小
   max-file-size: 50MB
   # 设置总上传的文件大小
   max-request-size: 120MB
# 服务模块
devtools:
 restart:
   # 热部署开关
   enabled: true

欢迎使用Markdown编辑器

你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。

新的改变

我们对Markdown编辑器进行了一些功能拓展与语法支持,除了标准的Markdown编辑器功能,我们增加了如下几点新功能,帮助你用它写博客:

  1. 全新的界面设计 ,将会带来全新的写作体验;
  2. 在创作中心设置你喜爱的代码高亮样式,Markdown 将代码片显示选择的高亮样式 进行展示;
  3. 增加了 图片拖拽 功能,你可以将本地的图片直接拖拽到编辑区域直接展示;
  4. 全新的 KaTeX数学公式 语法;
  5. 增加了支持甘特图的mermaid语法1 功能;
  6. 增加了 多屏幕编辑 Markdown文章功能;
  7. 增加了 焦点写作模式、预览模式、简洁写作模式、左右区域同步滚轮设置 等功能,功能按钮位于编辑区域与预览区域中间;
  8. 增加了 检查列表 功能。

功能快捷键

撤销:Ctrl/Command + Z
重做:Ctrl/Command + Y
加粗:Ctrl/Command + B
斜体:Ctrl/Command + I
标题:Ctrl/Command + Shift + H
无序列表:Ctrl/Command + Shift + U
有序列表:Ctrl/Command + Shift + O
检查列表:Ctrl/Command + Shift + C
插入代码:Ctrl/Command + Shift + K
插入链接:Ctrl/Command + Shift + L
插入图片:Ctrl/Command + Shift + G
查找:Ctrl/Command + F
替换:Ctrl/Command + G

合理的创建标题,有助于目录的生成

直接输入1次#,并按下space后,将生成1级标题。
输入2次#,并按下space后,将生成2级标题。
以此类推,我们支持6级标题。有助于使用TOC语法后生成一个完美的目录。

如何改变文本的样式

强调文本 强调文本

加粗文本 加粗文本

标记文本

删除文本

引用文本

H2O is是液体。

210 运算结果是 1024.

插入链接与图片

链接: link.

图片: Alt

带尺寸的图片: Alt

居中的图片: Alt

居中并且带尺寸的图片: Alt

当然,我们为了让用户更加便捷,我们增加了图片拖拽功能。

如何插入一段漂亮的代码片

博客设置页面,选择一款你喜欢的代码片高亮样式,下面展示同样高亮的 代码片.

// An highlighted block
var foo = 'bar';

生成一个适合你的列表

  • 项目
    • 项目
      • 项目
  1. 项目1
  2. 项目2
  3. 项目3
  • 计划任务
  • 完成任务

创建一个表格

一个简单的表格是这么创建的:

项目Value
电脑$1600
手机$12
导管$1

设定内容居中、居左、居右

使用:---------:居中
使用:----------居左
使用----------:居右

第一列第二列第三列
第一列文本居中第二列文本居右第三列文本居左

SmartyPants

SmartyPants将ASCII标点字符转换为“智能”印刷标点HTML实体。例如:

TYPEASCIIHTML
Single backticks'Isn't this fun?'‘Isn’t this fun?’
Quotes"Isn't this fun?"“Isn’t this fun?”
Dashes-- is en-dash, --- is em-dash– is en-dash, — is em-dash

创建一个自定义列表

Markdown
Text-to- HTML conversion tool
Authors
John
Luke

如何创建一个注脚

一个具有注脚的文本。2

注释也是必不可少的

Markdown将文本转换为 HTML

KaTeX数学公式

您可以使用渲染LaTeX数学表达式 KaTeX:

Gamma公式展示 Γ ( n ) = ( n − 1 ) ! ∀ n ∈ N \Gamma(n) = (n-1)!\quad\forall n\in\mathbb N Γ(n)=(n1)!nN 是通过欧拉积分

Γ ( z ) = ∫ 0 ∞ t z − 1 e − t d t   . \Gamma(z) = \int_0^\infty t^{z-1}e^{-t}dt\,. Γ(z)=0tz1etdt.

你可以找到更多关于的信息 LaTeX 数学表达式here.

新的甘特图功能,丰富你的文章

2014-01-07 2014-01-09 2014-01-11 2014-01-13 2014-01-15 2014-01-17 2014-01-19 2014-01-21 已完成 进行中 计划一 计划二 现有任务 Adding GANTT diagram functionality to mermaid
  • 关于 甘特图 语法,参考 这儿,

UML 图表

可以使用UML图表进行渲染。 Mermaid. 例如下面产生的一个序列图:

张三 李四 王五 你好!李四, 最近怎么样? 你最近怎么样,王五? 我很好,谢谢! 我很好,谢谢! 李四想了很长时间, 文字太长了 不适合放在一行. 打量着王五... 很好... 王五, 你怎么样? 张三 李四 王五

这将产生一个流程图。:

链接
长方形
圆角长方形
菱形
  • 关于 Mermaid 语法,参考 这儿,

FLowchart流程图

我们依旧会支持flowchart的流程图:

Created with Raphaël 2.3.0 开始 我的操作 确认? 结束 yes no
  • 关于 Flowchart流程图 语法,参考 这儿.

导出与导入

导出

如果你想尝试使用此编辑器, 你可以在此篇文章任意编辑。当你完成了一篇文章的写作, 在上方工具栏找到 文章导出 ,生成一个.md文件或者.html文件进行本地保存。

导入

如果你想加载一篇你写过的.md文件,在上方工具栏可以选择导入功能进行对应扩展名的文件导入,
继续你的创作。


  1. mermaid语法说明 ↩︎

  2. 注脚的解释 ↩︎

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值