POI 4.1.2 操作Excel的技巧 POI4.1.2操作Excel的快速应用_当前播报
POI 4.1.2 操作 Excel
(资料图)
1. POI 简介
POI(Poor Obfuscation Implementation),直译为“可怜的模糊实现”,利用POI接口可以通过 Java操作 Microsoft office 套件工具的读写功能。POI支持office的所有版本。
org.apache.poipoi4.1.2org.apache.poipoi-ooxml4.1.2
2. POI 的快速应用
(1)操作后缀为 .xls的 Excel文件
在 POI 中的几个主要对象:
HSSFWorkbookExcel 工作簿workbook
HSSFSheetExcel 工作表 sheet
HSSFRowExcel 行
HSSFCellExcel 单元格
使用 POI 创建 Excel
/** * 创建 Excel 测试 * @throws IOException 文件操作异常 */@Testpublic void createTest() throws IOException { // 新建工作薄 HSSFWorkbook workbook = new HSSFWorkbook(); // 新建工作表 HSSFSheet sheet = workbook.createSheet(); // 创建行,行号为 0 HSSFRow row = sheet.createRow(0); // 创建单元格,表示为第 3 个单元格 HSSFCell cell = row.createCell(2); // 输入值 cell.setCellValue("Hello World!"); // 将 Excel 进行文件导出 // 获取文件路径和文件 Path path = Paths.get(".").resolve("hello.xls"); // 文件已存在则删除 if (Files.exists(path)){ Files.delete(path); } // 创建文件 File file = Files.createFile(path).toFile(); // 写入数据 workbook.write(file);}
运行结果:
使用 POI 向 Excel 中追加
/** * 向已存在的 Excel 中追加内容 * @throws IOException */@Testpublic void appendTest() throws IOException { // 获取文件输入流 String path = "./hello.xls"; File file = new File(path); int rowIndex = 4; HSSFWorkbook workbook = null; HSSFSheet sheet = null; if(file.exists()){ FileInputStream fis = new FileInputStream(file); // 新建工作簿 workbook = new HSSFWorkbook(fis); // 新建工作表 sheet = workbook.getSheet("sheet0"); } else{ // 新建工作簿 workbook = new HSSFWorkbook(); // 新建工作表 sheet = workbook.createSheet(); } // 获取行号 HSSFRow row = sheet.getRow(rowIndex); // 判断是否存在,不存在则创建 if (row == null){ row = sheet.createRow(rowIndex); } // 创建单元格,表示为第 3 个单元格 HSSFCell cell = row.createCell(5); // 输入值 cell.setCellValue("追加3!"); // 将 Excel 进行文件导出 // 写入数据 workbook.write(file);}
运行结果:
使用 POI 读取 Excel
/** * 读取 Excel 测试 * @throws IOException 文件操作异常 */@Testpublic void readTest() throws IOException { // 读取 Excel 文件 // 获取文件路径和文件 FileInputStream fis = new FileInputStream("./hello.xls"); // 将输入流转换为工作簿对象 HSSFWorkbook workbook = new HSSFWorkbook(fis); // 获取第一个工作表 HSSFSheet sheet = workbook.getSheet("sheet0"); // 使用索引获取工作表 // HSSFSheet sheet = workbook.getSheetAt(0); // 获取指定行 HSSFRow row = sheet.getRow(0); // 获取指定列 HSSFCell cell = row.getCell(2); // 打印 System.out.println(cell.getStringCellValue());}
运行结果:
(2)操作后缀为 .xlsx的 Excel文件
在 POI 中的几个主要对象:
XSSFWorkbookExcel 工作簿workbook
XSSFSheetExcel 工作表 sheet
XSSFRowExcel 行
XSSFCellExcel 单元格
使用 POI 创建 Excel 表
/** * 创建以 .xlsx 为后缀的 Excel 测试 * @throws IOException 文件操作异常 */@Testpublic void createXlsxTest() throws IOException { // 新建工作簿 XSSFWorkbook workbook = new XSSFWorkbook(); // 新建工作表 XSSFSheet sheet = workbook.createSheet(); // 创建行,行号为 0 XSSFRow row = sheet.createRow(0); // 创建单元格,表示为第 3 个单元格 XSSFCell cell = row.createCell(2); // 输入值 cell.setCellValue("Hello World!"); // 将 Excel 进行文件导出 // 获取文件 File file = new File("./hello.xlsx"); // 如果文件存在则删除 if (file.exists()){ file.delete(); } // 创建输出流 FileOutputStream fos = new FileOutputStream(file); // 写入 workbook.write(fos); fos.close();}
运行结果:
使用 POI 追加 Excel 文件
/** * 向已存在以 .xlsx 为后缀的 Excel 中追加内容 * @throws IOException */@Testpublic void appendXlsxTest() throws IOException { // 获取文件输入流 String path = "./hello.xlsx"; File file = new File(path); int rowIndex = 4; XSSFWorkbook workbook = null; XSSFSheet sheet = null; if(file.exists()){ FileInputStream fis = new FileInputStream(file); // 新建工作簿 workbook = new XSSFWorkbook(fis); // 新建工作表 sheet = workbook.getSheet("sheet0"); } else{ // 新建工作簿 workbook = new XSSFWorkbook(); // 新建工作表 sheet = workbook.createSheet(); } // 创建行,行号为 0 XSSFRow row = sheet.getRow(rowIndex); // 判断是否存在,不存在则创建 if (row == null){ row = sheet.createRow(rowIndex); } // 创建单元格,表示为第 3 个单元格 XSSFCell cell = row.createCell(5); // 输入值 cell.setCellValue("追加内容1"); // 将 Excel 进行文件导出 FileOutputStream fos = new FileOutputStream(file); // 写入数据 workbook.write(fos);}
运行结果:
使用 POI 读取 Excel 文件
/** * 读取以 .xlsx 为后缀的 Excel 测试 * @throws IOException 文件操作异常 */@Testpublic void readXlsxTest() throws IOException { // 读取 Excel 文件 // 获取文件路径和文件 FileInputStream fis = new FileInputStream("./hello.xlsx"); // 将输入流转换为工作簿对象 XSSFWorkbook workbook = new XSSFWorkbook(fis); // 获取第一个工作表 XSSFSheet sheet = workbook.getSheet("sheet0"); // 使用索引获取工作表 // XSSFSheet sheet = workbook.getSheetAt(0); // 获取指定行 XSSFRow row = sheet.getRow(0); // 获取指定列 XSSFCell cell = row.getCell(2); // 打印 System.out.println(cell.getStringCellValue());}
运行结果:
(3)根据后缀名读取 Excel 文件
通过正则表达式读取
/** * 根据后缀名读取 Excel 文件 */@Testpublic void readAllExcel() throws IOException { // 两个不同后缀名文件的路径 String path1 = "./hello.xlsx"; String path2 = "./hello.xls"; readExcel(path1); readExcel(path2);}/** * 根据文件路径读取 Excel 文件 * @param path 文件路径 * @throws IOException 文件操作异常 */public void readExcel(String path) throws IOException { // 获取后缀 String suffix = path.substring(path.lastIndexOf(".")); // 判断后缀为 xls 还是 xlsx if (path.matches("^.+\\.(?i)((xls)|(xlsx))$")){ // 创建输入流 FileInputStream fis = new FileInputStream(path); // 判断是否为以 .xls 结尾的 Excel 文件 boolean isXlsExcel = path.matches("^.+\\.(?i)(xls)$"); // 判断后缀生成 工作簿 Workbook workbook = isXlsExcel ? new HSSFWorkbook(fis) : new XSSFWorkbook(fis); // 获取工作表 Sheet sheet = workbook.getSheet("sheet0"); // 获取指定行 Row row = sheet.getRow(0); // 获取指定列 Cell cell = row.getCell(2); // 输出值 System.out.println(suffix + " :\t" + cell.getStringCellValue()); }}
运行结果:
通过 WorkbookFactory 读取
/** * 通用读取的方法 */@Testpublic void generalRead() throws IOException { String path1 = "./hello.xls"; String path2 = "./hello.xlsx"; generalRead(path1); generalRead(path2);}public void generalRead(String path) throws IOException { File file = new File(path); Workbook workbook = WorkbookFactory.create(file); Sheet sheet = workbook.getSheet("sheet0"); String value = sheet.getRow(0).getCell(2).getStringCellValue(); String suffix = path.substring(path.lastIndexOf(".")+1); System.out.println(suffix + " :\t" + value);}
运行结果:
3. POI 的高级操作
(1)合并单元格
/** * 合并单元格 * CellRangeAddress(firstRow,lastRow,firstCol,lastCol) * 四个参数分别为 起使行号,终止行号,起使列,终止列 * * @throws IOException 文件操作异常 */@Testpublic void mergeCells() throws IOException { // 新建工作簿 HSSFWorkbook workbook = new HSSFWorkbook(); // 新建工作表 HSSFSheet sheet1 = workbook.createSheet("sheet1"); // 设置要合并的单元格范围,合并第二行的第二列到第五列为一个单元格 CellRangeAddress rangeAddress = new CellRangeAddress(1, 1, 1, 4); sheet1.addMergedRegion(rangeAddress); // 设置合并后的单元格内容 HSSFRow row = sheet1.createRow(1); HSSFCell cell = row.createCell(1); cell.setCellValue("我是合并后的单元格"); FileOutputStream outputStream = new FileOutputStream("./工作簿.xls"); workbook.write(outputStream); outputStream.close();}
运行结果:
注:上图中合并单元格后,单元格的名称是第一个单元格;即上面中合并了第二行的第二列到第五列,合并后的单元格叫 B2,而其它被合并的单元格已经无效了,不能对无效单元格设置值。如果进行了设置将不显示。
(2)设置单元格样式
/** * 设置单元格样式 * @throws IOException 文件操作异常 */@Testpublic void cellStyle() throws IOException { // 新建工作簿 HSSFWorkbook workbook = new HSSFWorkbook(); // 新建工作表 HSSFSheet sheet = workbook.createSheet("工作表1"); // 创建行 HSSFRow row = sheet.createRow(3); // 创建单元格 HSSFCell cell = row.createCell(3); cell.setCellValue("单元格内容"); // 设置sheet的第四列的宽度, 列宽单位是字符的1 / 256. sheet.setColumnWidth(3, 20 * 256); // 创建单元格样式 HSSFCellStyle style = workbook.createCellStyle(); // 设置单元格内容水平居中 style.setAlignment(HorizontalAlignment.CENTER); // 设置单元格内容垂直居中 style.setVerticalAlignment(VerticalAlignment.CENTER); // 创建字体 HSSFFont font = workbook.createFont(); font.setFontName(HSSFFont.FONT_ARIAL);//字体为Arial font.setColor(HSSFFont.COLOR_RED);//字体颜色为红色 font.setBold(true);//设置为粗体 font.setFontHeightInPoints((short) 16);//设置字体大小 style.setFont(font); // 设置填充模式,模式为全部前景色 style.setFillPattern(FillPatternType.SOLID_FOREGROUND); // 设置前景色为绿色 style.setFillForegroundColor(HSSFColorPredefined.GREEN.getColor().getIndex()); // 设置背景色,如果填充模式为其它填充模式,这个前景和背景色将相互交映显示 style.setFillBackgroundColor(HSSFColorPredefined.RED.getColor().getIndex()); // 为特定单元格设置样式 cell.setCellStyle(style); FileOutputStream fos = new FileOutputStream("./工.xls"); workbook.write(fos); fos.close();}
运行结果:
使用 POI 导入 Excel 文件到 MySQL 中
// 使用 Spring Test 测试,数据库操作可更改为普通的 JDBC 操作@RunWith(SpringJUnit4ClassRunner.class)@ContextConfiguration(locations = "classpath:applicationContext.xml")public class TestPoi { @Autowired private DataSource dataSource; @Test public void test() throws IOException, SQLException { // Excel 路径 String path = "./xxx.xlsx"; File file = new File(path); // 获取数据库连接 Connection conn = dataSource.getConnection(); // 插入的 SQL 语句 String sql = "insert into sheet1 values(null,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)"; PreparedStatement ps = conn.prepareStatement(sql); // 获取工作簿 Workbook workbook = WorkbookFactory.create(file); // 获取当前表 Sheet sheet = workbook.getSheetAt(0); // 获取总行数 int totalRows = sheet.getPhysicalNumberOfRows(); // 获取表头的总列数 int totalCols = sheet.getRow(0).getPhysicalNumberOfCells(); // 遍历行 for (int i = 1; i < totalRows; i++) { // 遍历列 for (int j = 0; j < totalCols; j++) { // 获取 i 行 j 列 Cell cell = sheet.getRow(i).getCell(j); // 判断该列是否为 null if (cell == null || cell.getCellType() == CellType.BLANK){ ps.setString(j+1,null); continue; } // 由于测试的 Excel 此处的最后一位为日期类型,这里使用日期输出 if (j==totalCols-1){ cell.setCellType(CellType.NUMERIC); System.out.println(new Date(cell.getDateCellValue().getTime())); ps.setDate(j+1,new Date(cell.getDateCellValue().getTime())); }else { // 判断是否是字符类型 if(cell.getCellType() == CellType.STRING){ ps.setString(j+1,cell.getStringCellValue()); }else{ // 单元格为数值类型 cell.setCellType(CellType.NUMERIC); ps.setInt(j+1, (int) cell.getNumericCellValue()); } } } // 执行 SQL ps.executeUpdate(); } ps.close(); conn.close(); }}
标签:
相关推荐:
最新新闻:
- 软件开发中的“OO”到底是什么?真实案例解析OO理论与实践-天天热门
- 推荐21个高质量图片网站 免费免版权值得收藏
- 世界最新:配置完Kafka集群后 通过JavaAPI方式来操作
- 什么是水冷机箱?水冷机箱和风冷机箱有什么区别?
- 如何解决显卡驱动无法正常安装?联想启天M6900介绍及驱动
- Office2003序列号有哪些?Office2003专业版序列号和注册码分享
- 艾尔文与花栗鼠2/花鼠明星俱乐部 详情介绍:世界快资讯
- 如何屏蔽热点资讯广告提示框?热点资讯怎么彻底卸载?
- 360加速球怎样开启?加速球一直红色应该怎样解决?
- usb音箱没有声音?音响插电视上没声音怎么设置?
- 如何通过邮件群发工资条?outlook群发工资条失败咋办?
- pp助手怎么修复闪退?pp助手有什么用?
- sbsettings怎么设置?sbsettings设置的具体步骤
- Fc2视频打不开了怎么办?打开Fc2视频的步骤
- 职务与职级并行套改表 新旧“职务与职级并行”套改与晋升实例 环球精选
- taobaoprotect.exe是什么进程?taobaoprotect.exe进程占用内存的解决方法
- java编程题:如何判断四个棋子连在一起?
- 出现此选项卡已经恢复是怎么回事?出现此选项卡已经恢复解决办法
- 全球时讯:免费下载国外视频的网站 你值得拥有
- 硬盘分区表都有什么修复方法?移动硬盘分区丢失后怎样找回?
- qq提取安装文件失败怎么办?压缩包无文件可提取咋回事?
- win10系统normal.dot在哪里?分享找到normal.dot文件的方法
- win7如何给文件设置密码?win7文件夹设置密码的具体步骤
- 如何做外链?做外链需要注意什么?
- 聚焦:为什么新拟态UI和可访问性是无法共存的?原因分析
- 圆形体癣是什么样子?圆圈状的癣不痛不痒的起因
- 东东助手显示无法连接服务器怎么办?模拟器常见问题及解决办法-天天热头条
- 【体验】Xoom评测:比iPad重50克 屏幕倒更大?
- secondary logon服务是什么?开启secondary logon服务详细方法
- 何删除定时器?MyLibco协程网络库定时器的设计
- 每日快播:泥巴潭:《新龙族》免费卷土重来 拒绝“菜鸟玩家”
- 3dmark05怎么安装?3dmark05注册码分享
- POI 4.1.2 操作Excel的技巧 POI4.1.2操作Excel的快速应用_当前播报
- 数学思想方法猜想与反驳 反例反驳在学习中的用处|热点
- Teracopy怎么样?Teracopy功能的及使用方法
- “东南亚小腾讯”大撤退,全面撤出欧洲市场
- 观速讯丨QQ邮箱发邮件受限制怎么办?SMTP发送邮件限制的解决方案
- 压铸模的使用特点是什么?压铸模的使用特点及使用原则
- 穿越时光隧道与古钓鱼城“面对面”|当前观察
- 天天热议:直降1000元 华硕 ProArt 创 16 2022 年终大促
- 游戏神U要来了 AMD居然定在情人节上市 全球观天下
- 每日简讯:最高6GHz睿频 英特尔13代酷睿i9-13900KS带来超凡体验
- 《霍格沃茨之遗》PC配置需求公布:推荐显卡1080 Ti
- FILA最好的时候已经过去?
- 当前资讯!《死亡空间:重制版》将采用2D地图 更易于使用!
- 黑鲨科技陨落,故事令人唏嘘_世界热文
- 《龙背上的农家》现已发售 Steam褒贬不一
- 【世界热闻】Q4利润增速一正一负,宁王让亿纬难望项背?| 见智研究
- 怪兽交配3D动作RPG新作《怪兽宇宙》1月上线
- 初代诞生26年 宝可梦种类现已超过1000种
- 环球今日讯!《三体》电视剧定档5小时 腾讯视频预约量突破200万
- 世界快资讯丨NS和《FIFA 23》是去年欧洲最畅销的主机/游戏
- 世界头条:《霍格沃茨之遗》使用D加密 系统需求最终版公布
- 全球快看:《尼尔:机械纪元》动画vs游戏画面对比视频分享
- 23长江C1票面利率为4.7000%:快看
- 环球视讯!《P3P》《P4G》新宣传片 售价均为148港币
- 《英雄联盟》Faker:LCK赛区整体比LPL赛区更强_速递
- 城市营造游戏《寓言之地》公布 登陆PC、支持中文
- 【焦点热闻】Xbox德国:《极限竞速》新作、《红霞岛》发售日将在直面会公开
- 武汉人的神秘邻居,有点萌:全球视讯
- 苹果新春电影《过五关》发布,用iPhone 14 Pro拍京剧,库克发文_环球速讯
- 2022年Q4传统PC出货量下降28% PC市场热潮已结束
- 《GTA:三部曲-终极版》即将登陆Steam平台:环球即时看
- 国产新冠药研发,都到哪一步了?
- 全球快报:海南文旅大盘再现违建,被罚1.23亿
- 全球速读:十倍变焦超远摄 适马60-600mm F4.5-6.3 DG DN OS发布
- 当现实中的尸体,变成你在游戏中打的丧尸-世界热门
- 天天快消息!《天龙八部之乔峰传》25日韩国上映 甄子丹将录韩版跑男
- 动作片《灭世男孩》首曝剧照 山姆·雷米监制-全球观焦点
- 国产模拟经营游戏《学园构想家》限时试玩版1月16日上线
- 世界看点:越是善解人意,越不爱社交不想聊天?
- 女子上班第一天因已婚被辞 公司赔偿100元误工费
- 快消息!《生化危机4:重制版》中配PV公开 艾达王亮相
- 纵向卡牌构筑肉鸽游戏《铁轨与墓穴》 将于2023Q1发售
- 《隐秘的角落》公布新预告 1月18日登录Steam 每日观点