日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

POI读取Excel文件时,row.getCell(0).getStringCellValue()报错:数字转换异常

發(fā)布時間:2025/3/12 编程问答 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 POI读取Excel文件时,row.getCell(0).getStringCellValue()报错:数字转换异常 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

在進行關鍵字驅動測試框架的搭建時,我們可能會遇到當單元格里的內容是手機號或者密碼等數(shù)字時使用row.getCell(0).getStringCellValue()這個方法是會報錯的,因為這牽扯到方法過時的原因:

所以我們可以使用以下的方法解決這個問題:

首先封裝一個類型轉換的方法getCellValue(),傳入獲取的cell

public static String getCellValue(Cell cell) {String cellValue = "";// 以下是判斷數(shù)據(jù)的類型switch (cell.getCellTypeEnum()) {case NUMERIC: // 數(shù)字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、讀取“區(qū)域數(shù)據(jù).xls”并儲存于list集合中,“區(qū)域數(shù)據(jù).xls”如下圖

public List<Area> importXLS(){ArrayList<Area> list = new ArrayList<>();try {//1、獲取文件輸入流InputStream inputStream = new FileInputStream("/Users/Shared/區(qū)域數(shù)據(jù).xls");//2、獲取Excel工作簿對象HSSFWorkbook workbook = new HSSFWorkbook(inputStream);//3、得到Excel工作表對象HSSFSheet sheetAt = workbook.getSheetAt(0);//4、循環(huán)讀取表格數(shù)據(jù)for (Row row : sheetAt) {//首行(即表頭)不讀取if (row.getRowNum() == 0) {continue;}//讀取當前行中單元格數(shù)據(jù),索引從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、導出數(shù)據(jù)到“區(qū)域數(shù)據(jù).xls”文件中,頁面數(shù)據(jù)如下圖:

public void exportExcel() throws IOException {Page<Area> page = areaService.pageQuery(null);List<Area> list = page.getContent();//1.在內存中創(chuàng)建一個excel文件HSSFWorkbook hssfWorkbook = new HSSFWorkbook();//2.創(chuàng)建工作簿HSSFSheet sheet = hssfWorkbook.createSheet();//3.創(chuàng)建標題行HSSFRow titlerRow = sheet.createRow(0);titlerRow.createCell(0).setCellValue("省");titlerRow.createCell(1).setCellValue("市");titlerRow.createCell(2).setCellValue("區(qū)");titlerRow.createCell(3).setCellValue("郵編");titlerRow.createCell(4).setCellValue("簡碼");titlerRow.createCell(5).setCellValue("城市編碼");//4.遍歷數(shù)據(jù),創(chuàng)建數(shù)據(jù)行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.創(chuàng)建文件名String fileName = "區(qū)域數(shù)據(jù)統(tǒng)計.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();//創(chuàng)建Excel工作簿對象 HSSFSheet sheet = wb.createSheet("new sheet");//創(chuàng)建Excel工作表對象 HSSFRow row = sheet.createRow((short)0); //創(chuàng)建Excel工作表的行 cellStyle = wb.createCellStyle();//創(chuàng)建單元格樣式 row.createCell((short)0).setCellStyle(cellStyle); //創(chuàng)建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的數(shù)目

wb.getNumberOfSheets()

5、 根據(jù)index取得sheet對象

HSSFSheet sheet = wb.getSheetAt(0);

6、取得有效的行數(shù)

int rowcount = sheet.getLastRowNum();

7、取得一行的有效單元格個數(shù)

row.getLastCellNum();

8、單元格值類型讀寫

cell.setCellType(HSSFCell.CELL_TYPE_STRING); //設置單元格為STRING類型 cell.getNumericCellValue();//讀取為數(shù)值類型的單元格內容

9、設置列寬、行高

sheet.setColumnWidth((short)column,(short)width); row.setHeight((short)height);

10、添加區(qū)域,合并單元格

Region region = new Region((short)rowFrom,(short)columnFrom,(short)rowTo ,(short)columnTo);//合并從第rowFrom行columnFrom列 sheet.addMergedRegion(region);// 到rowTo行columnTo的區(qū)域 //得到所有區(qū)域 sheet.getNumMergedRegions()

11、保存Excel文件

FileOutputStream fileOut = new FileOutputStream(path); wb.write(fileOut);

12、根據(jù)單元格不同屬性返回字符串數(shù)值

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: //數(shù)值類型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%"));//設置單元格數(shù)據(jù)格式 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); //創(chuàng)建一個工作薄 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()报错:数字转换异常的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。