导航:首页 > 编程语言 > javaexcel工具

javaexcel工具

发布时间:2025-03-22 09:57:59

java怎么操作excel合并单元格

利用java操作Excel,有个开源的东东-jxl.jar,可以到http://sourceforge.net/project/showfiles.php?group_id=79926下载。
一.读取Excel文件内容
java 代码

public static String readExcel(File file){
StringBuffer sb = new StringBuffer();

Workbook wb = null;
try {
//构造Workbook(工作薄)对象
wb=Workbook.getWorkbook(file);
} catch (BiffException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}

if(wb==null)
return null;

//获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了
Sheet[] sheet = wb.getSheets();

if(sheet!=null&&sheet.length>0){
//对每个工作表进行循环
for(int i=0;i
//得到当前工作表的行数
int rowNum = sheet[i].getRows();
for(int j=0;j
//得到当前行的所有单元格
Cell[] cells = sheet[i].getRow(j);
if(cells!=null&&cells.length>0){
//对每个单元格进行循环
for(int k=0;k
//读取当前单元格的值
String cellValue = cells[k].getContents();
sb.append(cellValue+"\t");
}
}
sb.append("\r\n");
}
sb.append("\r\n");
}
}
//最后关闭资源,释放内存
wb.close();
return sb.toString();
}
二.写入Excel文件
这里有很多格式了,比如文本内容加粗,加上某些颜色等,可以参考jxl的api,同时还推荐一篇不错的文章:http://www.ibm.com/developerworks/cn/java/l-javaExcel/?ca=j-t10
java 代码

public static void writeExcel(String fileName){
WritableWorkbook wwb = null;
try {
//首先要使用Workbook类的工厂方法创建一个可写入的工作薄(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++){
//这里需要注意的是,在Excel中,第一个参数表示列,第二个表示行
Label labelC = new Label(j, i, "这是第"+(i+1)+"行,第"+(j+1)+"列");
try {
//将生成的单元格添加到工作表中
ws.addCell(labelC);
} catch (RowsExceededException e) {
e.printStackTrace();
} catch (WriteException e) {
e.printStackTrace();
}

}
}

try {
//从内存中写入文件中
wwb.write();
//关闭资源,释放内存
wwb.close();
} catch (IOException e) {
e.printStackTrace();
} catch (WriteException e) {
e.printStackTrace();
}
}
}
三.在一个Excel文件中查找是否包含某一个关键字
java 代码

public static boolean searchKeyWord(File file,String keyWord){
boolean res = false;

Workbook wb = null;
try {
//构造Workbook(工作薄)对象
wb=Workbook.getWorkbook(file);
} catch (BiffException e) {
return res;
} catch (IOException e) {
return res;
}

if(wb==null)
return res;

//获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了
Sheet[] sheet = wb.getSheets();

boolean breakSheet = false;

if(sheet!=null&&sheet.length>0){
//对每个工作表进行循环
for(int i=0;i
if(breakSheet)
break;

//得到当前工作表的行数
int rowNum = sheet[i].getRows();

boolean breakRow = false;

for(int j=0;j
if(breakRow)
break;
//得到当前行的所有单元格
Cell[] cells = sheet[i].getRow(j);
if(cells!=null&&cells.length>0){
boolean breakCell = false;
//对每个单元格进行循环
for(int k=0;k
if(breakCell)
break;
//读取当前单元格的值
String cellValue = cells[k].getContents();
if(cellValue==null)
continue;
if(cellValue.contains(keyWord)){
res = true;
breakCell = true;
breakRow = true;
breakSheet = true;
}
}
}
}
}
}
//最后关闭资源,释放内存
wb.close();

return res;
}
四.往Excel中插入图片图标
插入图片的实现很容易,参看以下代码:
java 代码

public static void insertImg(WritableSheet dataSheet, int col, int row, int width,
int height, File imgFile){
WritableImage img = new WritableImage(col, row, width, height, imgFile);
dataSheet.addImage(img);
}
以上代码的注释已经很清楚了,大概也就不用再解释了,我们可以用如下程序验证:
java 代码
try {
//创建一个工作薄
WritableWorkbook workbook = Workbook.createWorkbook(new File("D:/test1.xls"));
//待插入的工作表
WritableSheet imgSheet = workbook.createSheet("Images",0);
//要插入的图片文件
File imgFile = new File("D:/1.png");
//图片插入到第二行第一个单元格,长宽各占六个单元格
insertImg(imgSheet,0,1,6,6,imgFile);
workbook.write();
workbook.close();
catch (IOException e) {
e.printStackTrace();
catch (WriteException e) {
e.printStackTrace();
但是jxl只支持png格式的图片,jpg格式和gif格式都不支持
五.插入页眉页脚
一般的页眉页脚都分为三个部分,左,中,右三部分,利用如下代码可实现插入页眉页脚
java 代码

public static void setHeader(WritableSheet dataSheet,String left,String center,String right){
HeaderFooter hf = new HeaderFooter();
hf.getLeft().append(left);
hf.getCentre().append(center);
hf.getRight().append(right);
//加入页眉
dataSheet.getSettings().setHeader(hf);
//加入页脚
//dataSheet.getSettings().setFooter(hf);
}
我们可以用如下代码测试该方法:
java 代码
try {
//创建一个工作薄
WritableWorkbook workbook = Workbook.createWorkbook(new File("D:/test1.xls"));
//待插入的工作表
WritableSheet dataSheet = workbook.createSheet("加入页眉",0);
ExcelUtils.setHeader(dataSheet, "chb", "2007-03-06", "第1页,共3页");
workbook.write();
workbook.close();
} catch (IOException e) {
e.printStackTrace();
} catch (WriteException e) {
e.printStackTrace();
}
}

合并单元格:
//首先创建一个sheet
WritableSheet sheetWrite=writeWorkbook.createSheet("sheet的名称",0);
//把 单元格(column, row)到单元格(column1, row1)进行合并。
sheetWrite.mergeCells(column, row, column1, row1);

java 操作excel,jxl加边框,jxl合并单元格,单元格的设置,单元
WritableCellFormat headerFormat = new WritableCellFormat(
HEADER_FONT_STYLE);
//水平居中对齐
headerFormat.setAlignment(Alignment.CENTRE);
//竖直方向居中对齐
headerFormat.setVerticalAlignment
(VerticalAlignment.CENTRE);

//建立标签,参数依次为:列索引、行索引、内容、格式
Label seqLabel = new Label(0, 0, "序号", headerFormat);
//增加单元格
sheet.addCell(seqLabel);
//合并单元格,参数依次为:列索引、行索引、列索引+需要合并
的列的个数、行索引+需要合并的行的个数
sheet.mergeCells(0, 0, 0, 1);
//设置单元格宽度,以字符为单位
sheet.setColumnView(0, "序号".length() + 10);
Label basicInfoLabel = new Label(1, 0, "基本信息",
headerFormat);
sheet.addCell(basicInfoLabel);
sheet.mergeCells(1, 0, 3, 0);//合并垮了3行。
sheet.mergeCells(1, 1, 1, 3);//合并垮了3列。

label = new Label(0, 1, "苹果”);
sheet.mergeCells(0,1, 0, 3- 1);//合并垮了3列。
WritableCellFormat cellFormat = new WritableCellFormat();
cellFormat.setVerticalAlignment(VerticalAlignment.CENTRE);
// 垂直居中
label.setCellFormat(cellFormat);
sheet.addCell(label);
注:再次使cellFormat时,需要重新NEW WritableCellFormat 。

❷ Java 缁椭xcel娣诲姞鏁板瓧绛惧悕 Excel VBA浣跨敤鏁板瓧绛惧悕


Java 缁椭xcel娣诲姞鏁板瓧绛惧悕 Excel VBA浣跨敤鏁板瓧绛惧悕銆侲xcel涓鍙娣诲姞鏁板瓧绛惧悕浠ヤ緵鏂囨。镓链夎呯敌鏄庢枃妗g殑镓链夋潈鎴栨湁鏁堟с备笅闱浠嬬粛濡备綍鍦↗ava绋嫔簭浠g爜涓瀹炵幇缁椭xcel宸ヤ綔绨挎坊锷犵惧悕銆
宸ュ叿/𨱒愭枡
Excel鐗堟湰锛2013
缂栬疟鐜澧冿细IntelliJ IDEA2018
JDK鐗堟湰锛1.8.0
Excel搴揿伐鍏凤细spire.xls.jar 4.3.4
鏁板瓧璇佷功鍙婂瘑镰
镎崭綔鏂规硶
01
鍦↖DEA椤圭洰鏂囦欢澶硅矾寰勪笅锛屽瓨鍏ヤ竴涓狤xcel鏂囦欢锛岀増链涓2013鐗堟湰镄刹lsx鏂囦欢;浠ュ强宸茬煡瀵嗙爜镄刾fx镙煎纺镄勬暟瀛楄瘉涔︺傚傚浘锛
02
鍦╥dea椤圭洰寮曞叆excel搴揿伐鍏穝pire.xls.jar镄勫寘锛屽傚浘锛
03
鍦ㄧ▼搴忎腑阌鍏ュ备笅浠g爜锛
import com.spire.xls.*;
import com.spire.xls.digital.CertificateAndPrivateKey;
import java.util.Date;
public class AddSignature {
public static void main(String[] args) throws Exception {
//锷犺浇Excel宸ヤ綔绨
Workbook wb = new Workbook();
wb.loadFromFile("test.xlsx");
//娣诲姞鏁板瓧绛惧悕
wb.addDigitalSignature(new CertificateAndPrivateKey("cer.pfx","123654yes!"), "The Author is Mia",new Date());
//淇濆瓨鏂囨。
wb.saveToFile("AddSignature.xlsx",ExcelVersion.Version2013);
wb.dispose();
}
}
04
镓ц岀▼搴忥纴鐢熸垚鏂囨。銆傚湪缁撴灉鏂囨。涓镆ョ湅绛惧悕娣诲姞鏁堟灉锛
1. 娣诲姞绛惧悕
import com.spire.xls.*;
import com.spire.xls.digital.CertificateAndPrivateKey;
import java.util.Date;
public class AddSignature {
public static void main(String[] args) throws Exception {
//锷犺浇Excel宸ヤ綔绨
Workbook wb = new Workbook();
wb.loadFromFile("test.xlsx");
//娣诲姞鏁板瓧绛惧悕
wb.addDigitalSignature(new CertificateAndPrivateKey("cer.pfx","123654yes!"), "The Author is Mia",new Date());
//淇濆瓨鏂囨。
wb.saveToFile("AddSignature.xlsx",ExcelVersion.Version2013);
wb.dispose();
}
}
2.妫娴嬫槸钖︾惧悕
import com.spire.xls.*;
public class DetectSignature {
public static void main(String[] args) {
//锷犺浇Excel宸ヤ綔绨
Workbook wb = new Workbook();
wb.loadFromFile("AddSignature.xlsx");
//鍒ゆ柇鏂囨。鏄钖︾惧悕
boolean signature = wb.isDigitallySigned();
if(signature==true)
{
System.out.println("鏂囨。宸茬惧悕!");
}
else
{
System.out.println("链绛惧悕鏂囨。!");
}
}
}
3.鍒犻櫎绛惧悕
import com.spire.xls.*;
public class RemoveSignature {
public static void main(String[] args) {
//锷犺浇Excel宸ヤ綔绨
Workbook wb = new Workbook();
wb.loadFromFile("AddSignature.xlsx");
//鍒犻櫎绛惧悕
wb.removeAllDigitalSignatures();
//淇濆瓨鏂囨。
wb.saveToFile("RemoveSignature.xlsx",ExcelVersion.Version2013);
wb.dispose();
}
}
镓ц岀▼搴忎唬镰佸悗锛岀敓鎴愮殑缁撴灉鏂囨。涓涓嶅啀链夌惧悕銆
鐗瑰埆鎻愮ず
浠g爜涓镄勮矾寰勪负IDEA椤圭洰鏂囦欢澶硅矾寰勶纴璺寰勪篃鍙鍙﹀栬嚜瀹氢箟銆

阅读全文

与javaexcel工具相关的资料

热点内容
程序员的职业乐趣 浏览:503
手机内置安全加密芯片有什么用 浏览:809
旧约pdf 浏览:101
小说网站正版授权分成源码 浏览:307
苹果手机app闪退是什么原因 浏览:788
安卓面试算法题 浏览:702
idle中怎么查看类库源码 浏览:304
云服务器购买租赁费用 浏览:617
linuxrename文件名 浏览:544
程序员凌晨三点不回家 浏览:70
牛宏伟手指速算法 浏览:984
方维众筹源码v17 浏览:572
centos建php网站 浏览:881
excel自定义算法 浏览:621
六个文件夹怎么压缩 浏览:520
美国服务器怎么设置汉语 浏览:304
重庆云服务器云计算 浏览:369
加密货币目标价 浏览:152
手机12g的文件哪里解压 浏览:708
乐视服务器异常是怎么回事 浏览:589