使用poi插件解析Excel文件
package com; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.nio.charset.Charset; import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; import java.util.List; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFDateUtil; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.springframework.stereotype.Component; import com.csvreader.CsvReader; import com.elin.csp.model.shopUser.entity.ShopUser; @Component public class InputExcelFileService { /** 总行数 */ private int totalRows = 0; /** 总列数 */ private int totalCells = 0; /** 错误信息 */ private String errorInfo; /** 构造方法 */ public InputExcelFileService() { } /** * * @描述:得到总行数 * * @时间:2011-8-9 下午04:27:34 * * @参数:@return * * @返回值:int */ public int getTotalRows() { return totalRows; } /** * * @描述:得到总列数 * * @时间:2011-8-9 下午04:27:45 * * @参数:@return * * @返回值:int */ public int getTotalCells() { return totalCells; } /** * * @描述:得到错误信息 * * @时间:2011-8-9 下午04:28:17 * * @参数:@return * * @返回值:String */ public String getErrorInfo() { return errorInfo; } /** * * @描述:验证excel文件 * * @时间:2011-8-9 下午04:06:47 * * @参数:@param fileName * * @参数:@return * * @返回值:boolean */ public boolean validateExcel(String fileName) { /** 检查文件名是否为空或者是否是Excel格式的文件 */ if (fileName == null || !(WDWUtil.isExcel2003(fileName) || WDWUtil .isExcel2007(fileName))) { errorInfo = "文件名不是excel格式"; return false; } /** 检查文件是否存在 */ File file = new File(fileName); if (file == null || !file.exists()) { errorInfo = "文件不存在"; return false; } return true; } /** * * @描述:根据文件名读取excel文件 * * @时间:2011-8-9 下午03:17:45 * * @参数:@param fileName * * @参数:@return * * @返回值:List */ public List<List<String>> read(String fileName) { List<List<String>> dataLst = new ArrayList<List<String>>(); InputStream is = null; try { /** 验证文件是否合法 */ if (!validateExcel(fileName)) { System.out.println(errorInfo); return null; } /** 判断文件的类型,是2003还是2007 */ boolean isExcel2003 = true; if (WDWUtil.isExcel2007(fileName)) { isExcel2003 = false; } /** 调用本类提供的根据流读取的方法 */ File file = new File(fileName); is = new FileInputStream(file); dataLst = read(is, isExcel2003); is.close(); } catch (Exception ex) { ex.printStackTrace(); } finally { if (is != null) { try { is.close(); } catch (IOException e) { is = null; e.printStackTrace(); } } } /** 返回最后读取的结果 */ return dataLst; } /** * * @描述:根据流读取Excel文件 * * @时间:2011-8-9 下午04:12:41 * * @参数:@param inputStream * * @参数:@param isExcel2003 * * @参数:@return * * @返回值:List */ public List<List<String>> read(InputStream inputStream, boolean isExcel2003) { List<List<String>> dataLst = null; try { /** 根据版本选择创建Workbook的方式 */ Workbook wb = isExcel2003 ? new HSSFWorkbook(inputStream) : new XSSFWorkbook(inputStream); dataLst = read(wb); } catch (IOException e) { e.printStackTrace(); } return dataLst; } /** * * @描述:读取数据 * * @时间:2011-8-9 下午04:37:25 * * @参数:@param wb * * @参数:@return * * @返回值:List<List<String>> */ private List<List<String>> read(Workbook wb) { List<List<String>> dataLst = new ArrayList<List<String>>(); /** 得到第一个shell */ Sheet sheet = wb.getSheetAt(0); /** 得到Excel的行数 */ this.totalRows = sheet.getPhysicalNumberOfRows(); /** 得到Excel的列数 */ if (this.totalRows >= 1 && sheet.getRow(0) != null) { this.totalCells = sheet.getRow(0).getPhysicalNumberOfCells(); } /** 循环Excel的行 */ for (int r = 0; r < this.totalRows; r++) { Row row = sheet.getRow(r); if (row == null) { continue; } List<String> rowLst = new ArrayList<String>(); /** 循环Excel的列 */ for (short c = 0; c < this.getTotalCells(); c++) { Cell cell = row.getCell(c); String cellValue = ""; if (cell == null) { rowLst.add(cellValue); continue; } /** 处理Excel的字符串 */ // cellValue = cell.getStringCellValue(); // rowLst.add(cellValue); switch (cell.getCellType()) { // 假如当前Cell的Type为NUMERIC case HSSFCell.CELL_TYPE_NUMERIC: { // 判定当前的cell是否为Date if (HSSFDateUtil.isCellDateFormatted(cell)) { // 假如是Date类型则,取得该Cell的Date值 Date date = cell.getDateCellValue(); // 把Date转换本钱地格式的字符串 cellValue = cell.getDateCellValue().toLocaleString(); } // 假如是纯数字 else { // 纯数字时,一般为电话号码或手机号,所以以字符串类型保存 cell.setCellType(Cell.CELL_TYPE_STRING); cellValue = cell.getStringCellValue(); // // 取得当前Cell的数值 // Integer num = new Integer((int) // cell.getNumericCellValue()); // cellValue = String.valueOf(num); } break; } // 假如当前Cell的Type为STRIN case HSSFCell.CELL_TYPE_STRING: // 取得当前的Cell字符串 cellValue = cell.getStringCellValue().replaceAll("'", "''"); break; // 默认的Cell值 default: cellValue = " "; } rowLst.add(cellValue); } /** 保存第r行的第c列 */ dataLst.add(rowLst); } return dataLst; } /** * * @描述:main测试方法 * * @时间:2011-8-9 下午04:31:35 * * @参数:@param args * * @参数:@throws Exception * * @返回值:void */ public static void main(String[] args) throws Exception { InputExcelFileService poi = new InputExcelFileService(); // List<List<String>> list = poi.read("d:/aaa.xls"); List<List<String>> list = poi.read("d:/aab.xlsx"); if (list != null) { for (int i = 0, ilen = list.size(); i < ilen; i++) { System.out.println("第" + (i + 1) + "行"); List<String> cellList = list.get(i); for (int j = 0, jlen = cellList.size(); j < jlen; j++) { System.out.print(" 第" + (j + 1) + "列值:"); System.out.println(cellList.get(j)); } } } } public List wdwExcelMethod(String path) { InputExcelFileService poi = new InputExcelFileService(); List<List<String>> list = poi.read(path); return list; } } /** * * @描述:工具类 * * @时间:2011-8-9 下午04:28:43 */ class WDWUtil { /** * * @描述:是否是2003的excel,返回true是2003 * * @时间:2011-8-9 下午03:20:49 * * @参数:@param fileName * * @参数:@return * * @返回值:boolean */ public static boolean isExcel2003(String fileName) { return fileName.matches("^.+\\.(?i)(xls)$"); } /** * * @描述:是否是2007的excel,返回true是2007 * * @时间:2011-8-9 下午03:21:37 * * @参数:@param fileName * * @参数:@return * * @返回值:boolean */ public static boolean isExcel2007(String fileName) { return fileName.matches("^.+\\.(?i)(xlsx)$"); } }

이 기사에서는 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 및 Gradle을 사용하여 접근 방식과 최적화 전략을 비교합니다.

이 기사에서는 Maven 및 Gradle과 같은 도구를 사용하여 적절한 버전 및 종속성 관리로 사용자 정의 Java 라이브러리 (JAR Files)를 작성하고 사용하는 것에 대해 설명합니다.

이 기사는 카페인 및 구아바 캐시를 사용하여 자바에서 다단계 캐싱을 구현하여 응용 프로그램 성능을 향상시키는 것에 대해 설명합니다. 구성 및 퇴거 정책 관리 Best Pra와 함께 설정, 통합 및 성능 이점을 다룹니다.

이 기사는 캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA를 사용하는 것에 대해 설명합니다. 잠재적 인 함정을 강조하면서 성능을 최적화하기위한 설정, 엔티티 매핑 및 모범 사례를 다룹니다. [159 문자]

Java의 클래스 로딩에는 부트 스트랩, 확장 및 응용 프로그램 클래스 로더가있는 계층 적 시스템을 사용하여 클래스로드, 링크 및 초기화 클래스가 포함됩니다. 학부모 위임 모델은 핵심 클래스가 먼저로드되어 사용자 정의 클래스 LOA에 영향을 미치도록합니다.

이 기사에서는 분산 응용 프로그램을 구축하기위한 Java의 원격 메소드 호출 (RMI)에 대해 설명합니다. 인터페이스 정의, 구현, 레지스트리 설정 및 클라이언트 측 호출을 자세히 설명하여 네트워크 문제 및 보안과 같은 문제를 해결합니다.

이 기사는 네트워크 통신을위한 Java의 소켓 API, 클라이언트 서버 설정, 데이터 처리 및 리소스 관리, 오류 처리 및 보안과 같은 중요한 고려 사항에 대해 자세히 설명합니다. 또한 성능 최적화 기술, i

이 기사에서는 맞춤형 Java 네트워킹 프로토콜을 작성합니다. 프로토콜 정의 (데이터 구조, 프레임, 오류 처리, 버전화), 구현 (소켓 사용), 데이터 직렬화 및 모범 사례 (효율성, 보안, Mainta를 포함합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

Dreamweaver Mac版
시각적 웹 개발 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기
