java对excel文件内容读写修改操作
Read.java
package domain; import java.io.FileInputStream;
import java.io.InputStream; import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook; public class Read {
public void readExcel(String filePath) { try { InputStream is = new FileInputStream(filePath); Workbook rwb = Workbook.getWorkbook(is); // 这里有两种方法获取sheet表:名字和下标(从0开始) // Sheet st = rwb.getSheet("original"); Sheet st = rwb.getSheet(0); /**
*
* //获得第一行第一列单元的值
*
* Cell c00 = st.getCell(0,0);
*
* //通用的获取cell值的方式,返回字符串
*
* String strc00 = c00.getContents();
*
* //获得cell具体类型值的方式
*
* if(c00.getType() == CellType.LABEL)
*
* {
*
* LabelCell labelc00 = (LabelCell)c00;
*
* strc00 = labelc00.getString();
*
* }
*
* //输出
*
* System.out.println(strc00);
*/ // Sheet的下标是从0开始 // 获取第一张Sheet表 Sheet rst = rwb.getSheet(0); // 获取Sheet表中所包含的总列数 int rsColumns = rst.getColumns(); // 获取Sheet表中所包含的总行数 int rsRows = rst.getRows(); // 获取指定单元格的对象引用 for (int i = 0; i < rsRows; i++) { for (int j = 0; j < rsColumns; j++) { Cell cell = rst.getCell(j, i); System.out.print(cell.getContents() + " "); } System.out.println(); } // 关闭 rwb.close(); } catch (Exception e) { e.printStackTrace(); } }
}
Writeadd.java
package domain; import java.io.File;
import java.io.OutputStream; import jxl.Workbook;
import jxl.format.UnderlineStyle;
import jxl.write.Boolean;
import jxl.write.DateFormat;
import jxl.write.DateTime;
import jxl.write.Label;
import jxl.write.Number;
import jxl.write.NumberFormat;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableImage;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook; public class Writeadd {
/** 输出Excel */ public void writeExcel(OutputStream os) { try { WritableWorkbook wwb = Workbook.createWorkbook(os); // 创建Excel工作表 指定名称和位置 WritableSheet ws = wwb.createSheet("Test Sheet 1", 0); /************** 往工作表中添加数据 *****************/ // 1.添加Label对象 Label label = new Label(5, 0, "测试");
Label labe2 = new Label(6, 0, "20163432");
Label labe3 = new Label(7, 0, "20163432"); ws.addCell(label);
ws.addCell(labe2);
ws.addCell(labe3); // 添加带有字型Formatting对象 WritableFont wf = new WritableFont(WritableFont.TIMES, 18, WritableFont.BOLD, true); WritableCellFormat wcf = new WritableCellFormat(wf); Label labelcf = new Label(1, 0, "hello word !", wcf); ws.addCell(labelcf); // 添加带有字体颜色的Formatting对象 WritableFont wfc = new WritableFont(WritableFont.ARIAL, 10, WritableFont.NO_BOLD, false, UnderlineStyle.NO_UNDERLINE, jxl.format.Colour.DARK_YELLOW); WritableCellFormat wcfFC = new WritableCellFormat(wfc); Label labelCF = new Label(1, 0, "石家庄铁道大学软件工程系", wcfFC); ws.addCell(labelCF); // 2.添加Number对象 Number labelN = new Number(0, 1, 3.1415926); ws.addCell(labelN); // 添加带有formatting的Number对象 NumberFormat nf = new NumberFormat("#.##"); WritableCellFormat wcfN = new WritableCellFormat(nf); Number labelNF = new jxl.write.Number(1, 1, 3.1415926, wcfN); ws.addCell(labelNF); // 3.添加Boolean对象 Boolean labelB = new jxl.write.Boolean(0, 2, true); ws.addCell(labelB); Boolean labelB1 = new jxl.write.Boolean(1, 2, false); ws.addCell(labelB1); // 4.添加DateTime对象 jxl.write.DateTime labelDT = new jxl.write.DateTime(0, 3, new java.util.Date()); ws.addCell(labelDT); // 5.添加带有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); // 6.添加图片对象,jxl只支持png格式图片 File image = new File("C:\\Users\\lenovo\\Desktop\\timg.png"); WritableImage wimage = new WritableImage(6, 4, 4, 20, image); ws.addImage(wimage); // 7.写入工作表 wwb.write(); wwb.close(); } catch (Exception e) { e.printStackTrace(); } } }
Update.java
package domain; import java.io.File; import jxl.CellType;
import jxl.Workbook;
import jxl.format.UnderlineStyle;
import jxl.write.Label;
import jxl.write.WritableCell;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook; public class Update { /**
* 将file1拷贝后,进行修改并创建输出对象file2
*
* 单元格原有的格式化修饰不能去掉,但仍可将新的单元格修饰加上去,
*
* 以使单元格的内容以不同的形式表现
*
*/ public void modifyExcel(File file1, File file2) { try { Workbook rwb = Workbook.getWorkbook(file1); WritableWorkbook wwb = Workbook.createWorkbook(file2, rwb);// copy WritableFont wfc = new WritableFont(WritableFont.ARIAL, 10, WritableFont.NO_BOLD, false, UnderlineStyle.NO_UNDERLINE, jxl.format.Colour.BLUE); WritableCellFormat wcfFC = new WritableCellFormat(wfc); WritableSheet ws = wwb.getSheet(0); WritableCell wc = ws.getWritableCell(0, 0); // 判断单元格的类型,做出相应的转换 if (wc.getType() == CellType.LABEL) { Label labelCF = new Label(1, 0, "人物(新)", wcfFC); ws.addCell(labelCF); Label label = (Label) wc; label.setString("被修改"); } wwb.write(); wwb.close(); rwb.close(); } catch (Exception e) { e.printStackTrace(); } } }
Zhuhanshu.java
package domain; import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.util.Scanner; public class Zhuhanshu { public static void main(String args[]) { // 读EXCEL
Read read = null; // 输出EXCEL
Writeadd writeadd = null; // 修改EXCEL Update update = null; try {
int n = 0; Scanner in = new Scanner(System.in);
while (n != 20) {
System.out.println("**********java实现对excel文件的读写修改操作××××××××××");
System.out.println("1.读取指定的excel文件内容的信息");
System.out.println("2.向excel文件中写入内容");
System.out.println("3.修改excel文件");// 添加信息 System.out.println("5.退出");
System.out.println("请选择:");
if (in.hasNextInt()) {
n = in.nextInt();
} else {
System.out.println("输入的不是整数,请重新输入:");
continue;
}
switch (n) {
case 1: {
// 读EXCEL
read = new Read();
read.readExcel("C:\\Users\\lenovo\\Desktop\\测试.xls"); break;
}
case 2: {
// 输出EXCEL
writeadd = new Writeadd();
File filewrite = new File("C:\\Users\\lenovo\\Desktop\\测试2.xls"); filewrite.createNewFile(); OutputStream os = new FileOutputStream(filewrite); writeadd.writeExcel(os);
System.out.println("执行完成");
break;
}
case 3: {
// 修改EXCEL
update = new Update();
update.modifyExcel(new File("C:\\Users\\lenovo\\Desktop\\测试.xls"),
new File("C:\\Users\\lenovo\\Desktop\\测试3.xls"));
System.out.println("执行完成");
break;
} case 5:
break;
default:
System.out.println("输入错误,请重新输入");
break;
}
} } catch (Exception e) {
e.printStackTrace();
}
} }
运行截图
源代码:https://pan.baidu.com/s/1cXgc2woaq5xrpkN4Pqhbeg
java对excel文件内容读写修改操作的更多相关文章
- Java 读取Excel 文件内容
在一个项目中,有一个需求,是把excel文件的内容转换为xml格式展示.在学习如何操作的过程中,首先是如何获取excel文件,其中操作的代码如下: 1.首先是导入需要的 jar, 下载地址:https ...
- java读取excel文件内容
1.导入依赖JAR包 <!-- jxl 操作excel --> <dependency> <groupId>org.jxls</groupId> < ...
- JXL包大解析;Java程序生成excel文件和解析excel文件内容
最近需求变化,需要把excel导入 我以前没有做过,所以我查了一些资料 和参考别人的代码 以下是多种方式: import java.io.File; import java.io.FileInputS ...
- python学习笔记(十三)-python对Excel进行读写修改操作
日常工作中会遇到Excel的读写问题.我们可以使用xlwt 模块将数据写入Excel表格,使用xlrd 模块从Excel读取数据,使用xlutils模块和xlrd模块结合对Excel数据进行修改.下面 ...
- Java 导入Excel文件到数据库
原文:http://www.jb51.net/article/44021.htm 项目中要求读取excel文件内容,并将其转化为xml格式.常见读取excel文档一般使用POI和JExcelAPI这两 ...
- PHP读取Excel文件内容
PHP读取Excel文件内容 项目需要读取Excel的内容,从百度搜索了下,主要有两个选择,第一个是PHPExcelReader,另外一个是PHPExcel. PHPExcelReader比较 ...
- 使用POI读取excel文件内容
1.前言 项目中要求读取excel文件内容,并将其转化为xml格式.常见读取excel文档一般使用POI和JExcelAPI这两个工具.这里我们介绍使用POI实现读取excel文档. 2.代码实例: ...
- 基于.net EF6 MVC5+WEB Api 的Web系统框架总结(4)-Excel文件读、写操作
Excel文件读.写可以使用Office自带的库(Microsoft.Office.Interop.Excel),前提是本机须安装office才能运行,且不同的office版本之间可能会有兼容问题.还 ...
- 第15.25节 PyQt(Python+Qt)入门学习:Model/View开发实战--使用QTableView展示Excel文件内容
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 一.概述 在前面的订阅专栏<第十九章.Model/View开发:QTableView的功能及属 ...
随机推荐
- bootstrap-3-fileinput上传案例
效果 导入的js和css <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/ ...
- 2-08. 用扑克牌计算24点(25) (ZJU_PAT 数学 枚举)
题目链接:http://pat.zju.edu.cn/contests/ds/2-08 一副扑克牌的每张牌表示一个数(J.Q.K分别表示11.12.13,两个司令都表示6).任取4张牌.即得到4个1~ ...
- Spring中的CharacterEncodingFilter
spring的配置文件如下: <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns=&q ...
- php : 开发记录(2017-03-10)
0.后台 循环N*10000次操作的简单处理 后台需要循环做N*10000次级别的工作时候,比如,发送邮件,推送通知.可以先把所有数据导入数据表(数据库操作所需的时间1~2秒),然后前台循环发送请求, ...
- H+ 编辑tab页 保存后 刷新列表tab页 并关闭自已。tabA页调用tabB页的方法
//注:在contabs.js文件中 $(function () { }); 方法外 加入 //注: data-name="' + menuName + '" 这句是加入的自定义属 ...
- Linux内核剖析(二)Linux内核绪论
什么是内核 内核是操作系统最基本的部分.它是为众多应用程序提供对计算机硬件的安全访问的一部分软件,这种访问是有限的,并且内核决定一个程序在什么时候对某部分硬件操作多长时间.内核的分类可分为单内核和双内 ...
- 微信小程序--相关资料
微信小程序Demo https://github.com/zce/weapp-demojustjavac/awesomewechatweapp: 微信小程序开发资源汇总 https://gith ...
- pandas.Dataframe复杂条件过滤
https://stackoverflow.com/questions/11418192/pandas-complex-filter-on-rows-of-dataframe mask = df.ap ...
- 【Vegas原创】SQLServer2008防小人利器:审核/审计功能
小人见怪不怪,世界上最可怕的就是会技术的小人,防不胜防! sa密码泄露也就算了,关键是人家也可以前台攻击,直接把你弄的没辙! 在诅咒这种小人的同时,除了加强服务器安全管理,密码策略等,SQL Serv ...
- 小米Pro 安装苹果系统
参考 http://www.miui.com/thread-11363672-1-1.html http://www.miui.com/thread-7601066-1-1.html https:// ...