【Java开源代码栏目提醒】:文章导读:在新的一年中,各位网友都进入紧张的学习或是工作阶段。网学会员整理了Java开源代码-TextOperatorExcel.java的相关内容供大家参考,祝大家在新的一年里工作和学习顺利!
package com.zf.s10;//创始一个包
import java.io.File;//引入类
import java.io.IOException;
import java.util.Scanner;
import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.format.UnderlineStyle;
import jxl.read.biff.BiffException;
import jxl.write.DateFormat;
import jxl.write.DateTime;
import jxl.write.Label;
import jxl.write.NumberFormat;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableImage;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;
public class TextOperatorExcel {// 操作Excel文件的类
public static String readExcel(File file) {// 读取Excel文件的内容
StringBuffer sb = new StringBuffer();
Workbook wb = null;
try {
wb = Workbook.getWorkbook(file);// 构造Workbook(工作薄)对象
} catch (Exception e) {// 捕获异常
e.printStackTrace();
}
if (wb == null)// 判断(工作薄)对象是否为空
return null;
Sheet[] sheet = wb.getSheets();// 创建Sheet(工作表)对象
if (sheet != null && sheet.length > 0) {// 工作表对象不为空
for (int i = 0; i < sheet.length; i++) {// 对每个工作表进行循环
int rowNum = sheet[i].getRows();// 得到当前工作表的行数
for (int j = 0; j < rowNum; j++) {
Cell[] cells = sheet[i].getRow(j);// 得到当前行的所有单元格
if (cells != null && cells.length > 0) {
for (int k = 0; k < cells.length; k++) {// 对每个单元格进行循环
String cellValue = cells[k].getContents();// 读取当前单元格的值
sb.append(cellValue + "\t");
}
}
sb.append("\r\n");
}
sb.append("\r\n");
}
}
wb.close();// 最后关闭资源,释放内存
return sb.toString();
}
public static void writeContentToExcel(String fileName) throws Exception{//将内容写入
File tempFile=new File(fileName);
WritableWorkbook workbook = Workbook.createWorkbook(tempFile);
WritableSheet sheet = workbook.createSheet("TestCreateExcel", 0);
//一些临时变量,用于写到excel中
Label l=null;
jxl.write.Number n=null;
jxl.write.DateTime d=null;
//预定义的一些字体和格式,同一个Excel中最好不要有太多格式
WritableFont headerFont = new WritableFont(WritableFont.ARIAL, 12, WritableFont.BOLD, false, UnderlineStyle.NO_UNDERLINE, jxl.format.Colour.BLUE);
WritableCellFormat headerFormat = new WritableCellFormat (headerFont);
WritableFont titleFont = new WritableFont(WritableFont.ARIAL, 10, WritableFont.NO_BOLD, false, UnderlineStyle.NO_UNDERLINE, jxl.format.Colour.RED);
WritableCellFormat titleFormat = new WritableCellFormat (titleFont);
WritableFont detFont = new WritableFont(WritableFont.ARIAL, 10, WritableFont.NO_BOLD, false, UnderlineStyle.NO_UNDERLINE, jxl.format.Colour.BLACK);
WritableCellFormat detFormat = new WritableCellFormat (detFont);
NumberFormat nf=new NumberFormat("0.00000"); //用于Number的格式
WritableCellFormat priceFormat = new WritableCellFormat (detFont, nf);
DateFormat df=new DateFormat("yyyy-MM-dd");//用于日期的
WritableCellFormat dateFormat = new WritableCellFormat (detFont, df);
l=new Label(0, 0, "用于测试的Excel文件", headerFormat);//创建一些单元格,再加到sheet中
sheet.addCell(l);
//添加标题
int column=0;
l=new Label(column++, 2, "标题", titleFormat);
sheet.addCell(l);
l=new Label(column++, 2, "日期", titleFormat);
sheet.addCell(l);
l=new Label(column++, 2, "货币", titleFormat);
sheet.addCell(l);
l=new Label(column++, 2, "价格", titleFormat);
sheet.addCell(l);
//添加内容
int i=0;
column=0;
l=new Label(column++, i+3, "标题 "+i, detFormat);
sheet.addCell(l);
d=new DateTime(column++, i+3, new java.util.Date(), dateFormat);
sheet.addCell(d);
l=new Label(column++, i+3, "CNY", detFormat);
sheet.addCell(l);
n=new jxl.write.Number(column++, i+3, 5.678, priceFormat);
sheet.addCell(n);
i++;
column=0;
l=new Label(column++, i+3, "标题 "+i, detFormat);
sheet.addCell(l);
d=new DateTime(column++, i+3, new java.util.Date(), dateFormat);
sheet.addCell(d);
l=new Label(column++, i+3, "SGD", detFormat);
sheet.addCell(l);
n=new jxl.write.Number(column++, i+3, 98832, priceFormat);
sheet.addCell(n);
//设置列的宽度
column=0;
sheet.setColumnView(column++, 20);
sheet.setColumnView(column++, 20);
sheet.setColumnView(column++, 10);
sheet.setColumnView(column++, 20);
workbook.write();
workbook.close();
System.out.println("内容写入"+fileName+"成功");
}
public static void writeExcel(String fileName) {//生成一个Excel文件
WritableWorkbook wwb = null;
try {
//创建一个可写入的工作薄(Workbook)对象
wwb = Workbook.createWorkbook(new File(fileName));
} catch (IOException e) {// 捕获流异常
e.printStackTrace();
}
if (wwb != null) {
// 创建一个可写入的工作表
// Workbook的createSheet方法有两个参数,第一个是工作表的名称,第二个是工作表在工作薄中的位置
WritableSheet ws = wwb.createSheet("sheet1", 0);
for (int i = 0; i < 10; i++) {// 循环添加单元格
for (int j = 0; j < 5; j++) {
Label labelC = new Label(j, i, "这是第" + (i + 1) + "行,第"
+ (j + 1) + "列");
try {
ws.addCell(labelC);// 将生成的单元格添加到工作表中
} catch (Exception e) {// 捕获异常
e.printStackTrace();
}
}
}
try {
wwb.write();// 从内存中写入文件中
wwb.close();// 从内存中写入文件中
} catch (Exception e) {// 捕获异常
e.printStackTrace();
}
}
System.out.println("生成一个Excel文件:"+fileName+"成功!");
}
public static boolean searchKeyWord(File file, String keyWord) {//搜索某一个文件中是否包含某个关键字
boolean res = false;
Workbook wb = null;
try {
wb = Workbook.getWorkbook(file);// 构造Workbook(工作薄)对象
} catch (Exception e) {// 捕获异常
return res;
}
if (wb == null)
return res;
Sheet[] sheet = wb.getSheets();//创建Sheet(工作表)对象
boolean breakSheet = false;
if (sheet != null && sheet.length > 0) {
for (int i = 0; i < sheet.length; i++) {// 对每个工作表进行循环
if (breakSheet)
break;
int rowNum = sheet[i].getRows();// 得到当前工作表的行数
boolean breakRow = false;
for (int j = 0; j < rowNum; j++) {// 循环获得行信息
if (breakRow)
break;
Cell[] cells = sheet[i].getRow(j);// 得到当前行的所有单元格
if (cells != null && cells.length > 0) {
boolean breakCell = false;
for (int k = 0; k < cells.length; k++) {// 对每个单元格进行循环
if (breakCell)
break;
String cellValue = cells[k].getContents();// 读取当前单元格的值
if (cellValue == null)
continue;
if (cellValue.contains(keyWord)) {//判断是否包含关键字
res = true;
breakC
上一篇:
TextOperatorArray.java
下一篇:
陕西师范大学远程教育学院毕业论文