POI读取Excel文件时,row.getCell(0).getStringCellValue()报错:数字转换异常
在進行關鍵字驅動測試框架的搭建時,我們可能會遇到當單元格里的內容是手機號或者密碼等數字時使用row.getCell(0).getStringCellValue()這個方法是會報錯的,因為這牽扯到方法過時的原因:
所以我們可以使用以下的方法解決這個問題:
首先封裝一個類型轉換的方法getCellValue(),傳入獲取的cell
public static String getCellValue(Cell cell) {String cellValue = "";// 以下是判斷數據的類型switch (cell.getCellTypeEnum()) {case NUMERIC: // 數字if (org.apache.poi.ss.usermodel.DateUtil.isCellDateFormatted(cell)) {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");cellValue = sdf.format(org.apache.poi.ss.usermodel.DateUtil.getJavaDate(cell.getNumericCellValue())).toString();} else {DataFormatter dataFormatter = new DataFormatter();cellValue = dataFormatter.formatCellValue(cell);}break;case STRING: // 字符串cellValue = cell.getStringCellValue();break;case BOOLEAN: // BooleancellValue = cell.getBooleanCellValue() + "";break;case FORMULA: // 公式cellValue = cell.getCellFormula() + "";break;case BLANK: // 空值cellValue = "";break;case ERROR: // 故障cellValue = "非法字符";break;default:cellValue = "未知類型";break;}return cellValue;}然后直接調用即可:
cell = excelSheet.getRow(rownum).getCell(cellnum); String cellData = getCellValue(cell);POI操作Excel
一、POI概述
Apache POI是Apache軟件基金會的開放源碼函式庫,POI提供API給Java程序對Microsoft Office格式檔案讀和寫的功能。
結構:
- HSSF - 提供讀寫Microsoft Excel格式檔案的功能。
- XSSF - 提供讀寫Microsoft Excel OOXML格式檔案的功能。
- HWPF - 提供讀寫Microsoft Word格式檔案的功能。
- HSLF - 提供讀寫Microsoft PowerPoint格式檔案的功能。
- HDGF - 提供讀寫Microsoft Visio格式檔案的功能。
使用必須引入依賴
<dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId> </dependency>二、HSSF概況
HSSF 是Horrible SpreadSheet Format的縮寫,通過HSSF,你可以用純Java代碼來讀取、寫入、修改Excel文件。HSSF 為讀取操作提供了兩類API:usermodel和eventusermodel,即“用戶模型”和“事件-用戶模型”。
三、 POI EXCEL文檔結構類
- HSSFWorkbook excel文檔對象
- HSSFSheet excel的sheet
- HSSFRow excel的行
- HSSFCell excel的單元格
- HSSFFont excel字體
- HSSFName 名稱
- HSSFDataFormat 日期格式
- HSSFHeader sheet頭
- HSSFFooter sheet尾
- HSSFCellStyle cell樣式
- HSSFDateUtil 日期
- HSSFPrintSetup 打印
- HSSFErrorConstants 錯誤信息表
四、EXCEL的讀寫操作
1、讀取“區域數據.xls”并儲存于list集合中,“區域數據.xls”如下圖
public List<Area> importXLS(){ArrayList<Area> list = new ArrayList<>();try {//1、獲取文件輸入流InputStream inputStream = new FileInputStream("/Users/Shared/區域數據.xls");//2、獲取Excel工作簿對象HSSFWorkbook workbook = new HSSFWorkbook(inputStream);//3、得到Excel工作表對象HSSFSheet sheetAt = workbook.getSheetAt(0);//4、循環讀取表格數據for (Row row : sheetAt) {//首行(即表頭)不讀取if (row.getRowNum() == 0) {continue;}//讀取當前行中單元格數據,索引從0開始String areaNum = row.getCell(0).getStringCellValue();String province = row.getCell(1).getStringCellValue();String city = row.getCell(2).getStringCellValue();String district = row.getCell(3).getStringCellValue();String postcode = row.getCell(4).getStringCellValue();Area area = new Area();area.setCity(city);area.setDistrict(district);area.setProvince(province);area.setPostCode(postcode);list.add(area);}//5、關閉流workbook.close();} catch (IOException e) {e.printStackTrace();}return list; }2、導出數據到“區域數據.xls”文件中,頁面數據如下圖:
public void exportExcel() throws IOException {Page<Area> page = areaService.pageQuery(null);List<Area> list = page.getContent();//1.在內存中創建一個excel文件HSSFWorkbook hssfWorkbook = new HSSFWorkbook();//2.創建工作簿HSSFSheet sheet = hssfWorkbook.createSheet();//3.創建標題行HSSFRow titlerRow = sheet.createRow(0);titlerRow.createCell(0).setCellValue("省");titlerRow.createCell(1).setCellValue("市");titlerRow.createCell(2).setCellValue("區");titlerRow.createCell(3).setCellValue("郵編");titlerRow.createCell(4).setCellValue("簡碼");titlerRow.createCell(5).setCellValue("城市編碼");//4.遍歷數據,創建數據行for (Area area : list) {//獲取最后一行的行號int lastRowNum = sheet.getLastRowNum();HSSFRow dataRow = sheet.createRow(lastRowNum + 1);dataRow.createCell(0).setCellValue(area.getProvince());dataRow.createCell(1).setCellValue(area.getCity());dataRow.createCell(2).setCellValue(area.getDistrict());dataRow.createCell(3).setCellValue(area.getPostcode());dataRow.createCell(4).setCellValue(area.getShortcode());dataRow.createCell(5).setCellValue(area.getCitycode());}//5.創建文件名String fileName = "區域數據統計.xls";//6.獲取輸出流對象HttpServletResponse response = ServletActionContext.getResponse();ServletOutputStream outputStream = response.getOutputStream();//7.獲取mimeTypeServletContext servletContext = ServletActionContext.getServletContext();String mimeType = servletContext.getMimeType(fileName);//8.獲取瀏覽器信息,對文件名進行重新編碼HttpServletRequest request = ServletActionContext.getRequest();fileName = FileUtils.filenameEncoding(fileName, request);//9.設置信息頭response.setContentType(mimeType);response.setHeader("Content-Disposition","attachment;filename="+fileName);//10.寫出文件,關閉流hssfWorkbook.write(outputStream);hssfWorkbook.close();}工具類
public class FileUtils {public static String filenameEncoding(String filename, HttpServletRequest request) throws IOException {String agent = request.getHeader("User-Agent"); //獲取瀏覽器if (agent.contains("Firefox")) {BASE64Encoder base64Encoder = new BASE64Encoder();filename = "=?utf-8?B?"+ base64Encoder.encode(filename.getBytes("utf-8"))+ "?=";} else if(agent.contains("MSIE")) {filename = URLEncoder.encode(filename, "utf-8");} else if(agent.contains ("Safari")) {filename = new String (filename.getBytes ("utf-8"),"ISO8859-1");} else {filename = URLEncoder.encode(filename, "utf-8");}return filename;} }寫出xls文件:
五、 EXCEL常用操作方法
1、 得到Excel常用對象
POIFSFileSystem fs=newPOIFSFileSystem(new FileInputStream("d:/test.xls")); //得到Excel工作簿對象 HSSFWorkbook wb = new HSSFWorkbook(fs); //得到Excel工作表對象 HSSFSheet sheet = wb.getSheetAt(0); //得到Excel工作表的行 HSSFRow row = sheet.getRow(i); //得到Excel工作表指定行的單元格 HSSFCell cell = row.getCell((short) j); cellStyle = cell.getCellStyle();//得到單元格樣式2、建立Excel常用對象
HSSFWorkbook wb = new HSSFWorkbook();//創建Excel工作簿對象 HSSFSheet sheet = wb.createSheet("new sheet");//創建Excel工作表對象 HSSFRow row = sheet.createRow((short)0); //創建Excel工作表的行 cellStyle = wb.createCellStyle();//創建單元格樣式 row.createCell((short)0).setCellStyle(cellStyle); //創建Excel工作表指定行的單元格 row.createCell((short)0).setCellValue(1); //設置Excel工作表的值3、設置sheet名稱和單元格內容
wb.setSheetName(1, "第一張工作表",HSSFCell.ENCODING_UTF_16); cell.setEncoding((short) 1); cell.setCellValue("單元格內容");4、取得sheet的數目
wb.getNumberOfSheets()5、 根據index取得sheet對象
HSSFSheet sheet = wb.getSheetAt(0);6、取得有效的行數
int rowcount = sheet.getLastRowNum();7、取得一行的有效單元格個數
row.getLastCellNum();8、單元格值類型讀寫
cell.setCellType(HSSFCell.CELL_TYPE_STRING); //設置單元格為STRING類型 cell.getNumericCellValue();//讀取為數值類型的單元格內容9、設置列寬、行高
sheet.setColumnWidth((short)column,(short)width); row.setHeight((short)height);10、添加區域,合并單元格
Region region = new Region((short)rowFrom,(short)columnFrom,(short)rowTo ,(short)columnTo);//合并從第rowFrom行columnFrom列 sheet.addMergedRegion(region);// 到rowTo行columnTo的區域 //得到所有區域 sheet.getNumMergedRegions()11、保存Excel文件
FileOutputStream fileOut = new FileOutputStream(path); wb.write(fileOut);12、根據單元格不同屬性返回字符串數值
public String getCellStringValue(HSSFCell cell) {String cellValue = "";switch (cell.getCellType()) {case HSSFCell.CELL_TYPE_STRING://字符串類型cellValue = cell.getStringCellValue();if(cellValue.trim().equals("")||cellValue.trim().length()<=0)cellValue=" ";break;case HSSFCell.CELL_TYPE_NUMERIC: //數值類型cellValue = String.valueOf(cell.getNumericCellValue());break;case HSSFCell.CELL_TYPE_FORMULA: //公式cell.setCellType(HSSFCell.CELL_TYPE_NUMERIC);cellValue = String.valueOf(cell.getNumericCellValue());break;case HSSFCell.CELL_TYPE_BLANK:cellValue=" ";break;case HSSFCell.CELL_TYPE_BOOLEAN:break;case HSSFCell.CELL_TYPE_ERROR:break;default:break;}return cellValue; }13、常用單元格邊框格式
HSSFCellStyle style = wb.createCellStyle(); style.setBorderBottom(HSSFCellStyle.BORDER_DOTTED);//下邊框 style.setBorderLeft(HSSFCellStyle.BORDER_DOTTED);//左邊框 style.setBorderRight(HSSFCellStyle.BORDER_THIN);//右邊框 style.setBorderTop(HSSFCellStyle.BORDER_THIN);//上邊框14、設置字體和內容位置
HSSFFont f = wb.createFont(); f.setFontHeightInPoints((short) 11);//字號 f.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);//加粗 style.setFont(f); style.setAlignment(HSSFCellStyle.ALIGN_CENTER);//左右居中 style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//上下居中 style.setRotation(short rotation);//單元格內容的旋轉的角度 HSSFDataFormat df = wb.createDataFormat(); style1.setDataFormat(df.getFormat("0.00%"));//設置單元格數據格式 cell.setCellFormula(string);//給單元格設公式 style.setRotation(short rotation);//單元格內容的旋轉的角度15、插入圖片
//先把讀進來的圖片放到一個ByteArrayOutputStream中,以便產生ByteArray ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream(); BufferedImage bufferImg = ImageIO.read(new File("ok.jpg")); ImageIO.write(bufferImg,"jpg",byteArrayOut); //讀進一個excel模版 FileInputStream fos = new FileInputStream(filePathName+"/stencil.xlt"); fs = new POIFSFileSystem(fos); //創建一個工作薄 HSSFWorkbook wb = new HSSFWorkbook(fs); HSSFSheet sheet = wb.getSheetAt(0); HSSFPatriarch patriarch = sheet.createDrawingPatriarch(); HSSFClientAnchor anchor = new HSSFClientAnchor(0,0,1023,255,(short) 0,0,(short)10,10); patriarch.createPicture(anchor , wb.addPicture(byteArrayOut.toByteArray(),HSSFWorkbook.PICTURE_TYPE_JPEG));16、調整工作表位置
HSSFWorkbook wb = new HSSFWorkbook(); HSSFSheet sheet = wb.createSheet("format sheet"); HSSFPrintSetup ps = sheet.getPrintSetup(); sheet.setAutobreaks(true); ps.setFitHeight((short)1); ps.setFitWidth((short)1);總結
以上是生活随笔為你收集整理的POI读取Excel文件时,row.getCell(0).getStringCellValue()报错:数字转换异常的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【深度学习】90.94%准确率!谷歌刷新
- 下一篇: 再见 Xshell!这个开源的终端工具更