`
ryan_ncu
  • 浏览: 70306 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

利用POI实现简单的Excel读写操作

    博客分类:
  • JAVA
阅读更多

利用POI实现简单的Excel读写操作

java 代码
  1. package test;   
  2.   
  3. import java.io.FileInputStream;   
  4. import java.io.FileOutputStream;   
  5.   
  6. import org.apache.poi.hssf.usermodel.HSSFCell;   
  7. import org.apache.poi.hssf.usermodel.HSSFRow;   
  8. import org.apache.poi.hssf.usermodel.HSSFSheet;   
  9. import org.apache.poi.hssf.usermodel.HSSFWorkbook;   
  10. import org.apache.poi.poifs.filesystem.POIFSFileSystem;   
  11.   
  12. public class POIExcelService    
  13. {   
  14.     private POIFSFileSystem fileSystem;   
  15.     private HSSFWorkbook workbook;   
  16.     private HSSFSheet sheet;   
  17.     private HSSFRow row;   
  18.     private HSSFCell cell;   
  19.        
  20.     public POIExcelService(){}   
  21.        
  22.     /**  
  23.      *   
  24.      * @param xlsPath  
  25.      */  
  26.     public POIExcelService(String xlsPath) throws Exception   
  27.     {   
  28.         this.fileSystem = new POIFSFileSystem(new FileInputStream(xlsPath));   
  29.         this.workbook = new HSSFWorkbook(fileSystem);   
  30.     }   
  31.        
  32.     /**  
  33.      * 获取单元格数据,以String格式返回  
  34.      * @param sheet  
  35.      * @param row  
  36.      * @param cell  
  37.      * @return  
  38.      */  
  39.     public String getCellValue(int sheet,int row,int cell)   
  40.     {   
  41.         setSheet(sheet);   
  42.         setRow(row);   
  43.         setCell(cell);   
  44.         return this.getCell().getStringCellValue();   
  45.     }   
  46.        
  47.     //导出文件   
  48.     public void Export(String xlsPath, int sheet, int row, int cell, String value) throws Exception   
  49.     {   
  50.         FileOutputStream fileOut = new FileOutputStream(xlsPath);       
  51.            
  52.         this.setSheet(sheet);   
  53.         this.setRow(row);   
  54.         this.setCell(cell);   
  55.         this.getCell().setCellValue(value);   
  56.              
  57.         this.workbook.write(fileOut);       
  58.          
  59.         fileOut.close();      
  60.            
  61.     }   
  62.        
  63.     public HSSFCell getCell() {   
  64.         return cell;   
  65.     }   
  66.   
  67.     public void setCell(int cell) {   
  68.         this.cell = this.row.getCell((short)(cell-1));    
  69.     }   
  70.   
  71.     public HSSFRow getRow() {   
  72.         return row;   
  73.     }   
  74.   
  75.     public void setRow(int row) {   
  76.         this.row = this.sheet.getRow(row-1);   
  77.     }   
  78.   
  79.     public HSSFSheet getSheet() {   
  80.         return sheet;   
  81.     }   
  82.   
  83.     public void setSheet(int sheet) {   
  84.         //默认是从0开始的,这里利用n-1转换下,用1开始,调用好理解点   
  85.         this.sheet = this.workbook.getSheetAt(sheet-1);   
  86.     }   
  87.        
  88.     /*  
  89.     public String getCellStringValue(HSSFCell cell) {     
  90.         String cellValue = "";     
  91.         switch (cell.getCellType()) {     
  92.         case HSSFCell.CELL_TYPE_STRING:     
  93.             cellValue = cell.getStringCellValue();     
  94.             if(cellValue.trim().equals("")||cellValue.trim().length()<=0)     
  95.                 cellValue=" ";     
  96.             break;     
  97.         case HSSFCell.CELL_TYPE_NUMERIC:     
  98.             cellValue = String.valueOf(cell.getNumericCellValue());     
  99.             break;     
  100.         case HSSFCell.CELL_TYPE_FORMULA:     
  101.             cell.setCellType(HSSFCell.CELL_TYPE_NUMERIC);     
  102.             cellValue = String.valueOf(cell.getNumericCellValue());     
  103.             break;     
  104.         case HSSFCell.CELL_TYPE_BLANK:     
  105.             cellValue=" ";     
  106.             break;     
  107.         case HSSFCell.CELL_TYPE_BOOLEAN:     
  108.             break;     
  109.         case HSSFCell.CELL_TYPE_ERROR:     
  110.             break;     
  111.         default:     
  112.             break;     
  113.         }     
  114.         return cellValue;     
  115.     }    
  116.     */  
  117.        
  118.        
  119.     public static void main(String[] args)    
  120.     {   
  121.         try {   
  122.             POIExcelService excelOper = new POIExcelService("产品项目导入模板.xls");   
  123.             String tmp = excelOper.getCellValue(111);   
  124.             System.out.println(tmp);   
  125.             excelOper.Export("产品项目导入模板_导出.xls",1,1,1,"ABCDE");   
  126.                            
  127.                
  128.         } catch (Exception e) {   
  129.             e.printStackTrace();   
  130.         }   
  131.   
  132.     }   
  133.        
  134.   
  135. }   
分享到:
评论

相关推荐

    DeepSeek入门宝典:赋能开发者实战的高性能AI解决方案

    内容概要:本文档详细介绍了 DeepSeek 这一高效、经济的人工智能解决方案,旨在为企业端、产品端以及开发者提供深度技术支持。对于企业而言,DeepSeek 带来了显著的成本效益和生产效率提升;而对于具体的产品和服务,它增强了用户体验的质量。特别是针对开发者,文档深入浅出地讲解了如何利用 DeepSeek 实现自动化代码生成、改写等辅助开发功能,并且提供了具体的步骤指导以满足不同环境下的部署需求,包括直接通过官方API接入、本地私有化部署或借助云平台进行托管的方式。 适合人群:希望降低开发门槛,提高工作效率的软件工程师和技术团队。 使用场景及目标:开发者可以根据自身条件选择最适合自己的部署方案来整合 DeepSeek 技术,进而达到优化编码过程、减少人为错误的目的。 其他说明:文中还包括了许多实际操作的例子,如通过代码改写的实例来展示如何改进现有程序段落,还有详细的API使用指南帮助初学者快速上手DeepSeek。此外,还提供了大量外部参考资料链接以便进一步扩展知识和技能范围。

    lusted_3cd_01_0318.pdf

    lusted_3cd_01_0318

    开源AI工具下载——Cherry-Studio-1.0.1-MACOS arm64版

    Cherry Studio是一款支持多模型服务的 Windows/macOS GPT 客户端。通过与Ollama搭配,搭建个人本地AI大模型

    chromedriver-win64-136.0.7058.0.zip

    chromedriver-win64-136.0.7058.0.zip

    matlab程序代码项目案例:使用 Simulink 进行自适应 MPC 设计

    matlab程序代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!

    mellitz_3cd_01_1116.pdf

    mellitz_3cd_01_1116

    基于MATLAB的牛顿迭代法实现

    基于MATLAB的牛顿迭代法实现

    steenman_01_0908.pdf

    steenman_01_0908

    [AB PLC例程源码][MMS_047737]System Time 64Bit Interpreted AOI.zip

    AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!

    stone_3ck_01a_0518.pdf

    stone_3ck_01a_0518

    [AB PLC例程源码][MMS_041473]Input Time Stamping.zip

    AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!

    lusted_3cd_01_1117.pdf

    lusted_3cd_01_1117

    2010-2023年 上市公司-管理层情感语调数据.zip

    管理层情感语调,或称为管理层语调,是一个在财务与会计领域中常用的概念,特别是在分析上市公司信息披露质量时。它主要指的是管理层在上市公司文字信息披露过程中,用词所体现出的情感倾向和可理解性。 本数据复刻了《财经研究》《中南财经政法大学学报》等顶级期刊的核心解释变量的做法。情感语调对企业未来盈余和未来绩效具有较强解释力、降低会计信息误定价、为分析师预测提供增量信息,而投资者也会对管理层情感语调做出积极反应。 情感语调1=(正面词汇数量-负面词汇数量)/词汇总量;数值越大,情感倾向越偏向正面积极。 情感语调2=(正面词汇数量-负面词汇数量)/(正面词汇数量+负面词汇数量);数值越大,情感倾向越偏向正面积极。 指标 证券代码、企业代码、年份、证券简称、行业代码、行业名称、正面词汇数量、负面词汇数量、词汇总量、句子数量、文字数量、情感语调1、情感语调2。

    mellitz_3cd_02_0318.pdf

    mellitz_3cd_02_0318

    moore_01_0909.pdf

    moore_01_0909

    lusted_3ck_02a_0119.pdf

    lusted_3ck_02a_0119

    pimpinella_3cd_01_0916.pdf

    pimpinella_3cd_01_0916

    [AB PLC例程源码][MMS_041392]Mill feed and Auxilary Control.zip

    AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!

    li_3ck_03_0919.pdf

    li_3ck_03_0919

    ofelt_3cd_01_0716.pdf

    ofelt_3cd_01_0716

Global site tag (gtag.js) - Google Analytics