package com.example.demo;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
public class QueryExcel {
public static void main(String[] args) {
// 读取Excel文件
File file = new File("D:/info.xls");
try {
//得到所有数据
List<List<String>> allData=readExcel(file);
//直接将它写到excel中
makeExcel(allData);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
private static List<List> readExcel(File file) throws Exception {
// 创建输入流,读取Excel
InputStream is = new FileInputStream(file.getAbsolutePath());
// jxl提供的Workbook类
Workbook wb = Workbook.getWorkbook(is);
// 只有一个sheet,直接处理
//创建一个Sheet对象
Sheet sheet = wb.getSheet(0);
// 得到所有的行数
int rows = sheet.getRows();
// 所有的数据
List<List<String>> allData = new ArrayList<List<String>>();
// 越过第一行 它是列名称
for (int j = 1; j < rows; j++) {
List<String> oneData = new ArrayList<String>();
// 得到每一行的单元格的数据
Cell[] cells = sheet.getRow(j);
for (int k = 0; k < cells.length; k++) {
oneData.add(cells[k].getContents().trim());
}
// 存储每一条数据
allData.add(oneData);
// 打印出每一条数据
System.out.println(oneData);
}
return allData;
}
public static void makeExcel(List<List<String>> result) {
//第一步,创建一个workbook对应一个excel文件
HSSFWorkbook workbook = new HSSFWorkbook();
//第二部,在workbook中创建一个sheet对应excel中的sheet
HSSFSheet sheet = workbook.createSheet("测试结果");
//第三部,在sheet表中添加表头第0行,老版本的poi对sheet的行列有限制
HSSFRow row = sheet.createRow(0);
//第四步,创建单元格,设置表头
HSSFCell cell = row.createCell(0);
cell.setCellValue("学号");
cell = row.createCell(1);
cell.setCellValue("姓名");
cell = row.createCell(2);
cell.setCellValue("用户名");
cell = row.createCell(3);
cell.setCellValue("密码");
cell = row.createCell(4);
cell.setCellValue("住址");
cell = row.createCell(5);
cell.setCellValue("result");
//第五步,写入数据
for(int i=0;i<result.size();i++) {
List<String> oneData = result.get(i);
HSSFRow row1 = sheet.createRow(i + 1);
for(int j=0;j<oneData.size();j++) {
//创建单元格设值
row1.createCell(j).setCellValue(oneData.get(j));
}
}
//将文件保存到指定的位置
try {
FileOutputStream fos = new FileOutputStream("E:\\result.xls");
workbook.write(fos);
System.out.println("写入成功");
fos.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}