当前位置:首页 > java > 正文内容

JAVA POI读取EXCEL 最简洁写法

关中浪子3年前 (2022-06-10)java2402
买泛域名SSL证书 送5斤装现摘猕猴桃一箱、同时提供技开源商城搭建免费技术支持。
泛域名ssl证书 239元1年送1个月、单域名39元1年,Sectigo(原Comodo证书)全球可信证书,强大的兼容性,高度安全性,如有问题7天内可退、可开发票
加微信VX 18718058521 备注SSL证书
【腾讯云】2核2G4M云服务器新老同享99元/年,续费同价
package com.sunland.poi;
 
import java.io.FileInputStream;
import java.io.IOException;
 
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
 
/**
 * 通过poi读取xml文件的所有内容,并输出
 * @author Administrator
 *
 */
public class OperateMicc {
	public static void main(String[] args) {
		String path = "C://x.xls";
		try {
			//读取xml文件
			HSSFWorkbook work = new HSSFWorkbook(new FileInputStream(path));
			//获取xml的表
			HSSFSheet sheet = work.getSheet("sheet1");
			//循环表的行
			for (int i = 0, snum = sheet.getPhysicalNumberOfRows(); i < snum; i++) {
				//获取一行数据
				HSSFRow row = sheet.getRow(i);
				StringBuffer buffer = new StringBuffer();
				//获取不到行数退出此次循环
				if (row == null)
					continue;
				//循环某行的列数据
				for (int t = 0, cnum = row.getPhysicalNumberOfCells(); t < cnum; t++) {
					//通过行获取列
					HSSFCell cell = row.getCell(t);
					
					if (cell == null)
						continue;
					//判断该行该列的单元格的类型,并获取该类型的值
					switch (cell.getCellType()) {
					case STRING:
						buffer.append(cell.getStringCellValue());
						break;
					case NUMERIC:
						buffer.append(cell.getNumericCellValue());
						break;
					case BLANK:
						buffer.append(" ");
						break;
					case BOOLEAN:
						buffer.append(cell.getBooleanCellValue());
						break;
					}
					;
					//获取单元格数据后与另一单元格腾出一个制表符的距离
					buffer.append("\t");
				}
				//输出该行的所有列数据
				System.out.println(buffer.toString());
			}
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}


找梯子最重要的就是稳定,这个已经上线三年了,一直稳定没有被封过,赶紧下载备用吧!

扫描二维码推送至手机访问。

版权声明:本文由码农翻生发布,如需转载请注明出处。

本文链接:https://lubojian.cn/post/183.html

分享给朋友:

相关文章

springboot 日期转换失败 解决方法

解决方法可以参考之前的链接springboot日期转换失败另外还有一种方式:直接在实体里面增加注解DateTimeFormat@DateTimeFormat(pattern="yyyy-MM-dd") private&...

poi4.0.0读取excel文件时报java.lang.NoClassDefFoundError: org/apache/commons/compress/archivers/zip/ZipFile

最近想用poi写个处理excel的工具,看了一下poi的官网,出了个4.0.0的版本,于是想尝尝鲜,下载了一把poi4.0.0的bin。下载的是下面的文件: 下载完,将压缩包里所有的jar包导入到工程中(当然,如果只需要处理exc...

简单两步配置 Maven远程仓库 阿里云镜像 【图文】

简单两步配置 Maven远程仓库 阿里云镜像 【图文】

为什么配置阿里云的镜像,是因为它比较快。咱国内的,赞1、打开Maven目录中conf目录下找打setting.xml右键打开;2、添加这段到mirrors标签中,默认这标签是没有什么内容的;<!-- 阿里云镜像 --> ...

Spring AOP的JDK动态代理和CGLIB代理 的原理

Spring AOP的JDK动态代理和CGLIB代理 的原理

一.AOP的概念         在软件业,AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统...

静态代理和动态代理的区别

静态代理静态代理,设计模式的代理模式举例通常是用这种方式实现的,对于每一个要代理的类为了添加相同的操作,需要分别去实现其接口,容易造成代理类过多public interface Subject {  ...

Spring Boot + MyBatis + MySQL 实现读写分离!不懂多看

Spring Boot + MyBatis + MySQL 实现读写分离!不懂多看

1、引言读写分离要做的事情就是对于一条SQL该选择哪个数据库去执行,至于谁来做选择数据库这件事儿,无非两个,要么中间件帮我们做,要么程序自己做。因此,一般来讲,读写分离有两种实现方式。第一种是依靠中间件(比如:MyCat),也就是说应用程序...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。