- 浏览: 476861 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
白天看黑夜:
PDMReader实现pdm建模快速导出word,html文件 ...
powerDesigner PDM格式导出常见问题 -
小黄牛:
分布一个Dubbo分布式架构项目实战参考内容:http://w ...
dubbo学习 -
Emotion_小寳:
无意中看见了,给悦神赞一个!
openResty安装 -
bewithme:
zy116494718 写道bewithme 写道Ffmpeg ...
ffmpeg实例 -
zy116494718:
bewithme 写道Ffmpeg 这个类哪里来的?楼主你偷来 ...
ffmpeg实例
读取:
JXL(Java Excel API)是一个用来动态读写Excel文件的开源框架,利用它可以在任何支持Java的操作系统上动态读写Excel文件。JXL的主页是:http://www.andykhan.com/jexcelapi/,可以在这里下载到它的最新的版本。
你可以分别通过如下命令
java -jar jxl.jar -xml test.xls
java -jar jxl.jar -cvs test.xls
以xml和cvs格式查看test.xls,这是因为JXL作者实现了一个用来演示的jxl.demo.Demo的类。
当然我们使用JXL主要是用它来动态读写Excel文件。现在就来看看JXL在对Excel的读和写上都提供了那些支持。
先来看看Excel文件中都有写上面对象
1 文件对象 2工作簿对象 3 单元格对象。
相应的在JXL中就有Workbook,Sheet ,Cell 。通过这三个对象我们就可以实现Excel文件的读取工作。
我们先想想一下读取步骤,不管是什么样的Excel操作框架必定都要经历
1选取Excel文件,2选择工作簿,3选择Cell,4读取信息。
那么现在就可以看看JXL中这四步骤如何体现:
//通过Workbook的静态方法getWorkbook选取Excel文件
Workbook workbook = Workbook.getWorkbook(new File("myfile.xls"));
//通过Workbook的getSheet方法选择第一个工作簿(从0开始)
Sheet sheet = workbook.getSheet(0);
//通过Sheet方法的getCell方法选择位置为C2的单元格(两个参数都从0开始)
Cell c2 = sheet.getCell(2,1); //第一个是列,第二个是行
//通过Cell的getContents方法把单元格中的信息以字符的形式读取出来
String stringc2 = c2.getContents();
可以看到正是刚才所说的四个步骤。
我们都知道Excel单元格是有格式的,那么这些信息如何取得。
Cell提供了一个getType方法能够返回单元格的类型信息,同时JXL提供了一个CellType类用来预设Excel中的类型信息,而且JXL提供了一些Cell类的子类用来分别用来表示各种类型的单元格,如LabelCell,NumberCell,DateCell分别表示字符、数值、日期类型的单元格。所以我们可以这样写:
if (c2.getType() == CellType.NUMBER)
{
NumberCell nc = (NumberCell) c2;
numberb2 = nc.getValue();
}
最后不要忘记关闭workbook以释放资源:
workbook.close();
现在总结一下:三个对象,四个步骤,注意格式。就可以轻松的从Excel文件中读取数据。
例:
String[] str = new String[5000]; File file = new File("D:\\1.xls"); Workbook workbook = Workbook.getWorkbook(file); Sheet sheet = workbook.getSheet(0); Cell cell = null; for(int i=0;i<sheet.getRows();i++){ cell = sheet.getCell(0,i); //第一个是列,第二个是行 //由于需求只读取第一列的 str[i] = cell.getContents(); } workbook.close();
写入:
1、建立一个xls文件
OutputStream os=new FileOutputStream("c:\\test.xls");
2、建立工作文件
WritableWorkbook wwb = Workbook.createWorkbook(os);
3、如果这个文件已经存在,那么我们可以在这个文件里面加入一个sheet为了和以前的数据进行分开;
jxl.write.WritableSheet ws = wwb.createSheet("Sheet 1", 0);
在createSheet方法里前面的参数是sheet名,后面是要操作的sheet号
4、写入数据
(1)最简单的字符型数据
Label label = new Label(0, 0, "This is a Label cell",wcfF);
ws.addCell(label);
在Label()方法里面有三个参数
第一个是代表列数,
第二是代表行数,
第三个代表要写入的内容
第四个是可选项,是输入这个label里面的样式
然后通过写sheet的方法addCell()把内容写进sheet里面。
字体样式:
WritableFont wf = new WritableFont(WritableFont.TIMES, 18, WritableFont.BOLD, true);
WritableFont()方法里参数说明:
这个方法算是一个容器,可以放进去好多属性
第一个: TIMES是字体大小,他写的是18
第二个: BOLD是判断是否为斜体,选择true时为斜体
第三个: ARIAL
第四个: UnderlineStyle.NO_UNDERLINE 下划线
第五个: jxl.format.Colour.RED 字体颜色是红色的
WritableCellFormat wcfF = new WritableCellFormat(wf);
(2)添加带有formatting的Number对象
NumberFormat nf = new NumberFormat("#.##");
(3)添加Number对象
(3.1)显示number对象数据的格式
NumberFormat nf = new NumberFormat("#.##");
WritableCellFormat wcfN = new WritableCellFormat(nf);
Number labelNF = new Number(1,1,3.1415926,wcfN);
ws.addCell(labelNF);
Number()方法参数说明:
前两上表示输入的位置
第三个表示输入的内容
(4)添加Boolean对象
Boolean labelB = new Boolean(0,2,false);
ws.addCell(labelB);
(5)添加DateTime对象
DateTime labelDT = new DateTime(0,3,new java.util.Date());
ws.addCell(labelDT);
DateTime()方法的参数说明
前两个表示输入的位置
第三个表示输入的当前时间
(6)添加带有formatting的DateFormat对象
这个显示当前时间的所有信息,包括年月日小时分秒
DateFormat df = new DateFormat("dd MM yyyy hh:mm:ss");
WritableCellFormat wcfDF = new WritableCellFormat(df);
DateTime labelDTF = new DateTime(1,3,new java.util.Date(),wcfDF);
ws.addCell(labelDTF);
(7)添加带有字体颜色Formatting的对象
WritableFont wfc = new WritableFont(WritableFont.ARIAL, 10, WritableFont.NO_BOLD, false,UnderlineStyle.NO_UNDERLINE, Colour.RED);
WritableCellFormat wcfFC = new WritableCellFormat(wfc);
import="jxl.format.*
WritableFont wfc = new WritableFont(WritableFont.ARIAL,20,WritableFont.BOLD,false,UnderlineStyle.NO_UNDERLINE,jxl.format.Colour.GREEN);
(8)设置单元格样式
WritableCellFormat wcfFC = new WritableCellFormat(wfc);
wcfFC.setBackGround(Colour.RED);//设置单元格的颜色为红色
wcfFC = new Label(6,0,"I love china",wcfFC);
例:
OutputStream os=new FileOutputStream("D:\\2.xls"); WritableWorkbook wwb = Workbook.createWorkbook(os); jxl.write.WritableSheet ws = wwb.createSheet("Sheet 1", 0); for(int i=0;phone[i]!=null;i++){ //phone为一个数组 Label label = new Label(0, i, phone[i]); //由于需求只在第一列输出 ws.addCell(label); } wwb.write(); wwb.close(); os.close();
发表评论
-
Future详解
2021-08-10 11:37 338一般使用线程池执行任务都是调用的execute方法,这个方法 ... -
CountDownLanch原理
2021-08-09 20:00 279文章转载自:https://segmentfault.com/ ... -
Java基础之Java8中Map的compute的使用
2020-10-10 18:57 1336假如我们现在有一需求,需要统计一个字符串中各个字母出现的频 ... -
java泛型实例
2019-06-15 21:09 834首先定义一个接口 ... -
Java 7 新的 try-with-resources 语句,自动资源释放
2019-04-25 14:41 468转载请注明出处:https ... -
java字节流与字符流的区别
2016-10-26 18:34 1275字节流与字符流 先来看一下流的概念: 在程序中所有的数 ... -
视频库之断点下载
2015-08-10 16:33 579断点续传主要是使用http协议中range的属性来取得资源的 ... -
视频库之断点续传
2015-07-30 11:37 1198近日公司有个项目要做一个视频库,故开始阶段 ... -
视频库之断点续传
2015-07-29 18:07 6近日公司有个项目要做一个视频库,故开始阶段性 ... -
数据库读写分离(java部分配置)
2015-06-15 15:26 2577假设有两台数据库服务器:192.168.0.1(写) 和1 ... -
图片压缩
2014-10-21 14:53 887下面方法可以做到压缩图片不失真: public c ... -
java图片合成
2013-11-05 16:52 2940下面这个例子介绍如何把3张图片合在一张图片里,用的是jav ... -
文件上传与下载
2013-01-16 10:03 1476文件下载: jsp: <input type=& ... -
线程池系列三:结合线程池实现Socket
2012-11-14 17:26 1450Java5增加了新的类库并发集java.util.concur ... -
线程池系列二:ThreadPoolExecutor讲解
2012-11-14 11:42 1580一、简介 1)线程池 ... -
线程池系列一:线程池作用及Executors方法讲解
2012-10-24 11:41 37613线程池的作用: 线程池作用就是限制系统中执行线 ... -
ArrayList 和 CopyOnWriteArrayList 线程安全测试
2012-10-19 17:48 1930ArrayList 是 非线程安全的, CopyOnWrite ... -
后台json传递
2012-06-21 15:38 4083json除了可以用于前台传递,还可用于后台之间传递。它可以传递 ... -
解决中文乱码问题
2012-05-18 14:42 2944首先可以试下在TOMCAT中 ... -
HttpClient应用
2012-05-11 17:15 1544用HttpClient爬网站时有时会遇到一种现象,就是自己写个 ...
相关推荐
医疗数据,用来java读取和写入excel用 医疗数据,用来java读取和写入excel用
Java 读取Excel写入值是一项...这就是使用jxl库在Java中读取和写入Excel的基本步骤。当然,jxl库还支持更复杂的操作,如格式化单元格、合并单元格、处理公式等。在实际应用中,可以根据需求进一步探索这些高级功能。
3. **写入Excel文件**: 创建新的Excel文件,你需要先创建一个XSSFWorkbook实例,然后添加新的Sheet,接着在Sheet上创建Row和Cell并设置值。最后,你需要通过FileOutputStream将Workbook写入文件。 ```java ...
Java 读取 Excel 写入 Excel
本文将深入探讨如何利用Java方便地读取和写入Excel文件,主要关注JExcelAPI这一库的使用。 首先,我们需要了解JExcelAPI,这是一个开源的Java库,它允许开发者直接操作Excel文件,而无需使用Microsoft Office或者...
写入Excel文件的过程则相对简单。下面是一个创建新Excel文件并写入数据的例子: ```java import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import java.io....
3. 写入Excel文件: 创建一个新的`Workbook`对象,然后添加新的`Sheet`,并写入数据: ```java WritableWorkbook newWorkbook = Workbook.createWorkbook(new File("output.xls")); WritableSheet newSheet = ...
总结来说,解决Java读取Excel内存溢出问题,关键在于合理利用资源、优化代码逻辑以及选择适合的API,如Apache POI的SXSSF。通过这些方法,我们可以在不显著增加系统资源负担的情况下,高效地处理大Excel文件。
对于写入Excel,我们需要创建`Row`和`Cell`,然后设置值: ```java Row newRow = sheet.createRow(rowIndex); Cell newCell = newRow.createCell(cellIndex); newCell.setCellValue("新值"); ``` 6. **关闭...
这里,我们将详细探讨如何使用Java来读取和导出Excel文件,主要涉及的技术包括Apache POI库和其他相关API的使用。 首先,Apache POI是一个流行的开源Java API,它允许开发人员创建、修改和显示Microsoft Office格式...
Java读取Excel文件可以使用Apache的POI(Poor Obfuscation Implementation)库,POI是一个开源的Java库,用于读取和写入Excel文件。POI支持Excel03和Excel07两种版本,当前最新的版本是3.8。 使用POI读取Excel文件...
本文将深入探讨如何使用Java来读取和写入Excel文件,以"java中读取Excel例子"为例,结合提供的文件"ExcellWriter.java",我们将详细讲解这个过程。 首先,Java中读取和写入Excel文件通常使用Apache POI库。Apache ...
Jxl是Java Excel API的简称,它是一个轻量级的库,专门用于读取和写入Excel文件。Jxl支持.xls格式,但不支持.xlsx格式。使用Jxl读取Excel文件的基本步骤如下: 1. 引入Jxl库:在项目中添加jxl.jar依赖。 2. 创建...
1、POI_EXCEL包下分别有两个类,一个是读取excel内容,一个是想excel写入内容 2、cn.itcast包下的所有包,是为了实现从excel写入到数据库中,和从数据库写入到excel中 注意事项: 1、需要导入maven工程 2、使用...
2. Excel 文件操作:Excel 文件操作是指使用 Java 语言对 Excel 文件进行读取、写入、删除等操作的过程。 3. JXL 库:JXL 库是指 Java Excel API,即 Java 语言对 Excel 文件的操作 API。 4. Workbook:Workbook 是...
在Java编程环境中,处理Excel文件是一项常见的任务,无论是读取现有数据还是生成新的报表。Java提供了多种库来方便开发者操作Excel文件,其中最常用的是Apache POI和JExcelAPI。本篇文章将主要聚焦于使用Apache POI...
为了在Unity中读取和写入Excel表格,通常需要引入一些外部库,如标题所提及的Excel.dll、ICSharpCode.SharpZipLib.dll和EPPlus.dll。下面将详细讲解这三个库的作用及其在Unity中的应用。 1. Excel.dll: 这是一个...
标题"java读取excel之xlsl超大文件"所涉及的核心知识点是优化大量数据的读取策略。在Java中,可以使用Apache POI的SXSSF API(Streaming Usermodel API)来实现这种优化。与常规的XSSF API不同,SXSSF允许我们以流的...