java使用poi简单操作excel

文章目录

    • 引言
    • 插入行/列
    • 合并单元格以及设置居中
    • 换行

引言

编程开发中,我们可能会接到某些需求,例如导出某某某列表数据,或者做一份报表,这时候就需要我们的poi出场了,至于一些规则数据的导出,直接使用easy-poi即可,操作简单,极易上手,在这里就不做过多的赘述,本文今天主要讲解一些poi原生的操作,以便于在老表格中对数据进行更新或者合并等

插入行/列

与其说插入,我们不如说是平移,给新的行/列留出位置,进行创建,废话不多说,我们直接上代码

/*** 平移,传入值为需要操作的文件*/private void shift(Workbook workbook) {// 获取第0个表格Sheet sheet = workbook.getSheetAt(0);// 移动行,第一个参数是起始行(0开始),第二个参数为最后一行,第三个参数为移动多少,正数向下,负数向上// 现在这个参数则是,从index是1的行到当前最后一行,整体向下平移2行sheet.shiftRows(1, sheet.getLastRowNum(), 2);// 移动列// index是1的列到index是3的列向右平移两列sheet.shiftColumns(1, 3, 2);}

合并单元格以及设置居中

合并单元格比较简单,但是需要注意,先合并单元格,再填充内容,否则很容易将单元格的已填充内容丢失。默认合并后保留第一个单元的内容

 private void merged(Workbook workbook) {Sheet sheet = workbook.getSheetAt(0);// 设置格式,都是通过CellStyle进行设置,其中可以设置字体、居中等属性CellStyle center = workbook.createCellStyle();// 这里设置水平居中,其他的直接看注释即可,当然,在这个位置只是创建样式,并未生效center.setAlignment(HorizontalAlignment.CENTER);// 创建一行,这里不用getRow()而使用create是因为get可能会存在行不存在的情况,会抛出空指针,后续的列也是如此Row row = sheet.createRow(1);Cell tf = row.createCell(0);tf.setCellValue("甲方名称");// 设置单元格内的样式必须在Cell中设置,否则不会生效tf.setCellStyle(center);// 这里是合并单元格,必须是Sheet对象。// 传入值是合并位置,这里表示(1,2,4,5都是下标),从第1行到第2行,其中的第4列和第5列的单元格合并为一个单元格sheet.addMergedRegion(new CellRangeAddress(1, 2, 4, 5));// 这里需要注意,即使是合并了单元格,原有的index也不会变,例如,第1,2个单元格合并后,他的index也是1,但是它占有的index也是1,2,后续的单元格就是3,4}

例如下图所示:
用1,2,3,4代表单元格下标
当1,2单元格合并后,合并后单元格index是1,但是3,4单元格的index还是3和4
在这里插入图片描述

换行

		// 这里有两个条件,第一个是\n标识换行,当然只是这个没用,第二个则是WrapText必须设置为trueint last = sheet.getLastRowNum();String format = "公司名称:%s \n 开户行:%s \n 账号:%s";format = String.format(format, vo.getSettlementCompany(), vo.getSettlementBank(), vo.getSettlementCard());Row bank = sheet.createRow(last + 1);bank.setHeight((short) 1000);Cell cell = bank.createCell(0);cell.setCellValue(format);// 设置格式CellStyle cellStyle = workbook.createCellStyle();// 设置自动换行cellStyle.setWrapText(true);cell.setCellStyle(cellStyle);

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

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

相关文章

vue项目设置的端口号运行后会自动加一问题解决

vue项目设置的端口号运行后会自动加一问题解决 主要原因是之前运行项目后没有完全的关闭服务,导致再次运行项目端口号被占用,自动加一! 问题解决 打开任务管理器,在进程中找到node相关进程,右键结束任务

Typescript初体验

Typescript Typescript 官网地址: https://www.typescriptlang.org/zh/ 使用 nvm 来管理 node 版本: https://github.com/nvm-sh/nvm 装 Typescript: npm install -g typescript使用 tsc 全局命令: // 查看 tsc 版本 tsc -v // 编译 ts 文件 tsc fileName.ts1.…

利用数字人技术“活”化吉祥物,打造“科技+”数融盛会

在第十四届全国冬季运动会上,吉祥物“蒙古彩娃”安达和塞努不再同于往常静态的吉祥物形象,而是升级为生动活泼、能够与观众实时互动的数字人形象,活跃于赛事宣传、场馆介绍等多个场景,为本届冰雪盛会注入数字活力,提升…

RoboRAVE世界机器人大会亚洲分会toio™专项挑战顺利收官,toio™实现“双首次”突破

2024年2月21日,北京——2024 RoboRAVE国际教育机器人大会(下称RoboRAVE)亚洲分会toio™专项挑战在北京科技大学成功举办。现场云集来自华北、华南、华东等全国各地40组杰出学生队伍,展开热烈的机器人编程限时挑战。本届toio™专项…

并发编程入门指南

文章目录 并发编程进程和线程的区别并发和并行的区别创建线程的方式线程之间的状态,状态之间的转换新建三个线程,如何保证按顺序执行wait方法和sleep的区别如何停止一个正在运行的线程synchronized关键字底层原理Monitor属于重量级锁,了解过锁…

day04_流程语句_if_while_for

今日内容 1.if 2.switch 3.while,do-while,for 零、复习 1算术运算符中除法特性 整数相除不保留小数 10/33 2什么作用,i和i什么区别 让数据自增1i,是在后先使用后自增i,是在前先自增后使用 3&& 和 & 有相同点和不同点 相同点: 两边判断式子,一错就错全对才对不同点…

一文了解web开发基础知识【HTML、CSS、JavaScript】

文章目录 1 前言1.1 HTML1.2 CSS1.3 JavaScript1.4 理解HTML、CSS、JavaScript之间的关系 2 HTML2.1 什么是网页2.2 什么是HTML2.2.1 文本内容2.2.1.1 标题 2.2.2 图像2.2.3 链接2.2.4 列表2.2.5 表格2.2.6 HTML代码注释 2.3 第一个HTML文件2.3.1 示例2.3.2 补充2.3.2.1 < l…

苹果iPad通过Code APP应用实现SSH连接服务器远程进行开发

文章目录 1. 在iPad下载Code APP2.安装cpolar内网穿透2.1 cpolar 安装2.2 创建TCP隧道 3. iPad远程vscode4. 配置固定TCP端口地址4.1 保留固定TCP地址4.2 配置固定的TCP端口地址4.3 使用固定TCP地址远程vscode 本文主要介绍开源iPad应用IDE Code App 如何下载安装&#xff0c;并…

基于springboot + vue实现的前后端分离-酒店管理系统

项目介绍 基于springboot vue实现的酒店管理系统一共有酒店管理员和用户这两种角色。 管理员功能 登录&#xff1a;管理员可以通过登录功能进入系统&#xff0c;确保只有授权人员可以访问系统。用户管理&#xff1a;管理员可以添加、编辑和删除酒店的用户&#xff0c;包括前…

运维SRE-18 自动化批量管理-ansible4

12.2handles handles触发器(条件)&#xff0c;满足条件后再做什么事情应用场景&#xff1a;想表示&#xff1a;配置文件变化&#xff0c;再重启服务 配置handlers之前&#xff0c;每次运行剧本都会重启nfs&#xff0c;无论配置文件是否变化。 [rootm01 /server/ans/playbook]…

C++--输入一个数字判断是否是素数

一.算法思路 要判断数字n是否是素数&#xff0c;那么用n除以一个2~根号n的数字i&#xff0c;若有一个被整除&#xff0c;说明n不是素数&#xff0c;否则是素数 二.完整代码 #include<cmath> #include<iostream> bool IsPrime(int n) {for (int i 2;i < sqrt(n…

【MATLAB GUI】 1. 普通按钮、静态文本和可编辑文本

看B站up主freexyn的freexyn编程实例视频教程系列36Matlab GUI的学习笔记 文章目录 初步认识普通按钮静态文本和可编辑文本设计一个简易计算机 初步认识普通按钮 任务要求&#xff1a;点击一次“100”按钮&#xff0c;按钮上的文字值就递增1&#xff1b;点击“close”按钮&…

UniApp中打开蓝牙所需哪些权限

Hello&#xff0c;各位同学们新年好呀&#xff0c;咱们又见面了&#xff01;我是咕噜铁蛋&#xff01;随着移动应用的普及&#xff0c;蓝牙技术正变得越来越重要。在UniApp中&#xff0c;打开蓝牙功能为我们提供了更多便利和创新的可能性。然而&#xff0c;很多人可能不清楚在U…

【计算机网络】socket 网络套接字

网络套接字 一、端口号1. 认识端口号2. socket 二、认识TCP协议和UDP协议1. TCP协议2. UDP协议 三、网络字节序四、socket 编程1. socket 常见API2. sockaddr 结构3. 编写 UDP 服务器&#xff08;1&#xff09;socket()&#xff08;2&#xff09;bind()&#xff08;3&#xff0…

【Unity编辑器扩展】Unity编辑器主题颜色设置工具

可以用来应用和自定义你的Unity编辑器。14个主题可供选择。轻松创建自己的主题。 主题展示:

明御运维审计与风险控制系统漏洞复现

简介 明御运维审计与风险控制系统是安恒信息在多年运维安全管理的理论和实践经验积累的基础上,采用B/S架构,集“身份认证、账户管理、控制权限、日志审计”于一体,支持多种字符终端协议、文件传输协议、图形终端协议、远程应用协议的安全监控与历史查询,具备全方位运维风险…

ChatGPT丨“成像光谱遥感技术中的AI革命:ChatGPT应用指南“

遥感技术主要通过卫星和飞机从远处观察和测量我们的环境&#xff0c;是理解和监测地球物理、化学和生物系统的基石。ChatGPT是由OpenAI开发的最先进的语言模型&#xff0c;在理解和生成人类语言方面表现出了非凡的能力。本文重点介绍ChatGPT在遥感中的应用&#xff0c;人工智能…

【医学大模型】临床推理 + 大模型,推理感知型诊断框架

临床推理 大模型&#xff0c;推理感知型诊断框架 提出背景Module II-1: 少数样本CoT推理Module II-2: 单模态学生蒸馏Module II-3: 多模态学生蒸馏 提出背景 论文&#xff1a;https://arxiv.org/pdf/2312.07399.pdf 这篇文章提出了一种新的诊断框架&#xff0c;专注于利用大型…

Android T 远程动画显示流程其二——动画的添加流程(更新中)

前言 接着上篇文章分析 Android T 远程动画显示流程其一 切入点——处理应用的显示过渡 下面&#xff0c;我们以从桌面点击一个应用启动的场景来分析远程动画的流程&#xff0c;窗口添加的流程见Android T WMS窗口相关流程 这里我们从AppTransitionController.handleAppTran…

HAL STM32 HW I2C DMA + SSD1306/SH1106驱动示例

HAL STM32 HW I2C DMA SSD1306/SH1106驱动示例 &#x1f4cd;硬件I2C DMA驱动参考&#xff1a;https://blog.csdn.net/weixin_45065888/article/details/118225993 &#x1f4cc;github上的相关项目&#xff1a;https://github.com/taburyak/STM32_OLED_SSD1306_HAL_DMA &am…