package download;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.Date;
import jxl.Cell;
import jxl.CellType;
import jxl.Sheet;
import jxl.Workbook;
import jxl.WorkbookSettings;
import jxl.format.Alignment;
import jxl.format.Border;
import jxl.format.BorderLineStyle;
import jxl.format.Colour;
import jxl.format.VerticalAlignment;
import jxl.write.Formula;
import jxl.write.Label;
import jxl.write.NumberFormat;
import jxl.write.WritableCellFeatures;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
public class OperateExcel {
/**
* @param args
*/
/**
* 生成Excel文件
*
* @param path
* 文件路径
* @param sheetName
* 工作表名称
* @param dataTitles
* 数据标题
*/
public void createExcelFile(String path, String sheetName,
String[] dataTitles) {
WritableWorkbook workbook;
try {
OutputStream os = new FileOutputStream(path);
workbook = Workbook.createWorkbook(os);
WritableSheet sheet = workbook.createSheet(sheetName, 0); // 添加第一个工作表
initialSheetSetting(sheet);
Label label;
for (int i = 0; i < dataTitles.length; i++) {
// Label(列号,行号,内容,风格)
label = new Label(i, 0, dataTitles.toString(), getTitleCellFormat());
sheet.addCell(label);
}
// 插入一行
insertRowData(sheet, 1, new String[] { "200201001", "张三", "100",
"60", "100", "260" },
getDataCellFormat(CellType.STRING_FORMULA));
// 一个一个插入行
label = new Label(0, 2, "200201002",
getDataCellFormat(CellType.STRING_FORMULA));
sheet.addCell(label);
label = new Label(1, 2, "李四",
getDataCellFormat(CellType.STRING_FORMULA));
sheet.addCell(label);
insertOneCellData(sheet, 2, 2, 70.5,
getDataCellFormat(CellType.NUMBER));
insertOneCellData(sheet, 3, 2, 90.523,
getDataCellFormat(CellType.NUMBER));
insertOneCellData(sheet, 4, 2, 60.5,
getDataCellFormat(CellType.NUMBER));
insertFormula(sheet, 5, 2, "C3+D3+E3",
getDataCellFormat(CellType.NUMBER_FORMULA));
// 插入日期
mergeCellsAndInsertData(sheet, 0, 3, 5, 3, new Date(),
getDataCellFormat(CellType.DATE));
workbook.write();
workbook.close();
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 初始化表格属性
*
* @param sheet
*/
public void initialSheetSetting(WritableSheet sheet) {
try {
// sheet.getSettings().setProtected(true); //设置xls的保护,单元格为只读的
sheet.getSettings().setDefaultColumnWidth(10); // 设置列的默认宽度
// sheet.setRowView(2,false);//行高自动扩展
// setRowView(int row, int height);--行高
// setColumnView(int col,int width); --列宽
sheet.setColumnView(0, 20);// 设置第一列宽度
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 插入公式
*
* @param sheet
* @param col
* @param row
* @param formula
* @param format
*/
public void insertFormula(WritableSheet sheet, Integer col, Integer row,
String formula, WritableCellFormat format) {
try {
Formula f = new Formula(col, row, formula, format);
sheet.addCell(f);
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 插入一行数据
*
* @param sheet
* 工作表
* @param row
* 行号
* @param content
* 内容
* @param format
* 风格
*/
public void insertRowData(WritableSheet sheet, Integer row,
String[] dataArr, WritableCellFormat format) {
try {
Label label;
for (int i = 0; i < dataArr.length; i++) {
label = new Label(i, row, dataArr.toString(), format);
sheet.addCell(label);
}
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 插入单元格数据
*
* @param sheet
* @param col
* @param row
* @param data
*/
public void insertOneCellData(WritableSheet sheet, Integer col,
Integer row, Object data, WritableCellFormat format) {
try {
if (data instanceof Double) {
jxl.write.Number labelNF = new jxl.write.Number(col, row,
(Double) data, format);
sheet.addCell(labelNF);
} else if (data instanceof Boolean) {
jxl.write.Boolean labelB = new jxl.write.Boolean(col, row,
(Boolean) data, format);
sheet.addCell(labelB);
} else if (data instanceof Date) {
jxl.write.DateTime labelDT = new jxl.write.DateTime(col, row,
(Date) data, format);
sheet.addCell(labelDT);
setCellComments(labelDT, "这是个创建表的日期说明!");
} else {
Label label = new Label(col, row, data.toString(), format);
sheet.addCell(label);
}
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 合并单元格,并插入数据
*
* @param sheet
* @param col_start
* @param row_start
* @param col_end
* @param row_end
* @param data
* @param format
*/
public void mergeCellsAndInsertData(WritableSheet sheet, Integer col_start,
Integer row_start, Integer col_end, Integer row_end, Object data,
WritableCellFormat format) {
try {
sheet.mergeCells(col_start, row_start, col_end, row_end);// 左上角到右下角
insertOneCellData(sheet, col_start, row_start, data, format);
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 给单元格加注释
*
* @param label
* @param comments
*/
public void setCellComments(Object label, String comments) {
WritableCellFeatures cellFeatures = new WritableCellFeatures();
cellFeatures.setComment(comments);
if (label instanceof jxl.write.Number) {
jxl.write.Number num = (jxl.write.Number) label;
num.setCellFeatures(cellFeatures);
} else if (label instanceof jxl.write.Boolean) {
jxl.write.Boolean bool = (jxl.write.Boolean) label;
bool.setCellFeatures(cellFeatures);
} else if (label instanceof jxl.write.DateTime) {
jxl.write.DateTime dt = (jxl.write.DateTime) label;
dt.setCellFeatures(cellFeatures);
} else {
Label _label = (Label) label;
_label.setCellFeatures(cellFeatures);
}
}
/**
* 读取excel
*
* @param inputFile
* @param inputFileSheetIndex
* @throws Exception
*/
public ArrayList<String> readDataFromExcel(File inputFile,
int inputFileSheetIndex) {
ArrayList<String> list = new ArrayList<String>();
Workbook book = null;
Cell cell = null;
WorkbookSettings setting = new WorkbookSettings();
java.util.Locale locale = new java.util.Locale("zh", "CN");
setting.setLocale(locale);
setting.setEncoding("ISO-8859-1");
try {
book = Workbook.getWorkbook(inputFile, setting);
} catch (Exception e) {
e.printStackTrace();
}
Sheet sheet = book.getSheet(inputFileSheetIndex);
for (int rowIndex = 0; rowIndex < sheet.getRows(); rowIndex++) {// 行
for (int colIndex = 0; colIndex < sheet.getColumns(); colIndex++) {// 列
cell = sheet.getCell(colIndex, rowIndex);
// System.out.println(cell.getContents());
list.add(cell.getContents());
}
}
book.close();
return list;
}
/**
* 得到数据表头格式
*
* @return
*/
public WritableCellFormat getTitleCellFormat() {
WritableCellFormat wcf = null;
try {
// 字体样式
WritableFont wf = new WritableFont(WritableFont.TIMES, 12,
WritableFont.NO_BOLD, false);// 最后一个为是否italic
wf.setColour(Colour.RED);
wcf = new WritableCellFormat(wf);
// 对齐方式
wcf.setAlignment(Alignment.CENTRE);
wcf.setVerticalAlignment(VerticalAlignment.CENTRE);
// 边框
wcf.setBorder(Border.ALL, BorderLineStyle.THIN);
// 背景色
wcf.setBackground(Colour.GREY_25_PERCENT);
} catch (WriteException e) {
e.printStackTrace();
}
return wcf;
}
/**
* 得到数据格式
*
* @return
*/
public WritableCellFormat getDataCellFormat(CellType type) {
WritableCellFormat wcf = null;
try {
// 字体样式
if (type == CellType.NUMBER || type == CellType.NUMBER_FORMULA) {// 数字
NumberFormat nf = new NumberFormat("#.00");
wcf = new WritableCellFormat(nf);
} else if (type == CellType.DATE || type == CellType.DATE_FORMULA) {// 日期
jxl.write.DateFormat df = new jxl.write.DateFormat(
"yyyy-MM-dd hh:mm:ss");
wcf = new jxl.write.WritableCellFormat(df);
} else {
WritableFont wf = new WritableFont(WritableFont.TIMES, 10,
WritableFont.NO_BOLD, false);// 最后一个为是否italic
wcf = new WritableCellFormat(wf);
}
// 对齐方式
wcf.setAlignment(Alignment.CENTRE);
wcf.setVerticalAlignment(VerticalAlignment.CENTRE);
// 边框
wcf.setBorder(Border.LEFT, BorderLineStyle.THIN);
wcf.setBorder(Border.BOTTOM, BorderLineStyle.THIN);
wcf.setBorder(Border.RIGHT, BorderLineStyle.THIN);
// 背景色
wcf.setBackground(Colour.WHITE);
wcf.setWrap(true);// 自动换行
} catch (WriteException e) {
e.printStackTrace();
}
return wcf;
}
/**
* 打开文件看看
*
* @param exePath
* @param filePath
*/
public void openExcel(String exePath, String filePath) {
Runtime r = Runtime.getRuntime();
String cmd[] = { exePath, filePath };
try {
r.exec(cmd);
} catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
String[] titles = { "学号", "姓名", "语文", "数学", "英语", "总分" };
OperateExcel jxl = new OperateExcel();
String filePath = "D:/test.xls";
jxl.createExcelFile(filePath, "成绩单", titles);
//jxl.readDataFromExcel(new File(filePath), 0);
//jxl.openExcel("C:/Program Files/Microsoft Office/OFFICE11/EXCEL.EXE",filePath);
}
}
分享到:
相关推荐
9. 资源链接:`http://zjava.org.ru/`可能是提供相关教程或代码示例的网站,访问该网站可能有助于获取更多关于如何实现这一转换的详细信息。 10. 文件接口和曾国复试答案:在提供的文件名列表中,“接口.rar”可能...
4. **读取Excel文件**: - 使用HSSF,你可以创建一个`HSSFWorkbook`对象来读取`.xls`文件。 - 使用XSSF,你需要创建一个`XSSFWorkbook`对象来读取`.xlsx`文件。 5. **写入Excel文件**: - 类似地,你可以使用`...
System.out.println("读取Excel文件失败:" + e.getMessage()); } } } ``` #### 六、总结 通过以上两个示例,我们可以看到使用Apache POI进行Excel文件的操作非常直观且易于理解。无论是创建新的Excel文件还是...
《使用JXL库读取Excel文件详解》 在IT领域,数据处理是不可或缺的一部分,而Excel作为常用的电子表格工具,其文件格式(如.xls或.xlsx)在数据交换中扮演着重要角色。Java作为一种广泛使用的编程语言,对于处理...
在本文中,我们将深入探讨如何使用Visual Studio 2008中的Microsoft Foundation Classes (MFC)库来读取Excel文件中的数据。MFC是微软提供的一套C++类库,它为开发Windows应用程序提供了丰富的接口和支持。对于需要与...
使用Apache POI,开发者可以创建、修改和读取Excel文件。在Java中,我们可以创建`HSSFWorkbook`对象来表示工作簿,`HSSFSheet`表示工作表,`HSSFRow`代表行,`HSSFCell`表示单元格。通过这些对象,我们可以填充数据...
在服务器端,使用Java POI读取上传的Excel文件内容,可能需要解析单元格的数据类型、样式和公式。 3. **Excel导出**:服务器端处理业务逻辑后,将结果数据写入新的Excel文件并提供给用户下载。这个过程可能涉及到...
2. `main` 方法是程序的入口点,它创建了一个 `Excel2JSONHelper` 实例,并调用 `readExcle` 方法来读取Excel文件并将其转换为JSONArray。 3. `getExcel2JSONHelper` 是一个静态方法,用于获取`Excel2JSONHelper` ...
Excel 宏读取 SAP 数据方法详解 Excel 宏读取 SAP 数据方法是指使用 Excel 宏从 SAP 系统中读取数据。这种方法可以实现直接从 Excel 输出报表数据的关键是sap Web Services。下面是该方法的详细介绍。 首先,需要...
/** 读取Excel表格数据 */ public List, String>> readExcel(String excelName, Integer sheetIndex, String startPoint, String endPoint) throws Exception { FileInputStream inputStream = null; ...
利用开源组件POI3.0.2,用java语言实现了动态导出Excel文档,并且也实现了Excel文档的导入。有完整的例子,可直接使用。ExportExcel类为导出Excel报表通用类。 1.将源代码导入eclipse中 2.部署项目,启动tomcat...
这个过程通常包括读取Excel文件中的数据,解析工作表,然后按照JSON的语法规则构造对象和数组,最后将结果写入到一个或多个JSON文件(如"json")中。"tool"可能是这个转换过程中的核心程序或者辅助工具,可能是用...
在描述中提到的"阿里EasyExcel读取Excel的java工具类",实际上是指EasyExcel提供的一系列Java类和接口,它们可以帮助我们方便地读取Excel文件。EasyExcel的核心组件包括`ExcelReader`和`ExcelWriter`,分别用于读取...
本项目“ReadService.7z”专注于利用Java来读取Excel文件,然后向其中写入数据,并最终生成一个新的Excel文件。在这个过程中,我们可能会涉及到几个关键的技术点和API,包括但不限于Apache POI库、JSON数据格式以及...
在这个项目中,MyBatis用于执行Excel数据的CRUD操作,如读取Excel数据到数据库,或者从数据库获取数据并导出到Excel。 3. **Excel上传**:在Web应用中,Excel上传功能通常使用Apache POI库来实现。Apache POI是用于...
标题中的“excel_z2002h_spreadsheet_TheJust_excel_源码.zip”表明这是一个关于Excel的源码文件,可能是一个编程项目或者是一系列用于处理Excel数据的代码。这个压缩包的名称暗示了它可能包含的是针对Excel 2002...
4. **读取Excel和Word文档** - 打开现有文件时,使用WorkbookFactory.create()方法,传入文件流或文件路径。 - 对于Excel,可以通过getSheetAt(int index)获取工作表,通过getRow(int row)获取行,通过getCell(int...
Apache POI提供了Java API,可以读取、写入Microsoft Office格式的文件,包括Excel。导入时,从Excel文件读取数据并存入数据库;导出时,从数据库中获取数据并生成Excel文件供用户下载。 6. **上传下载**:在web...
在给定的压缩包“易语言源码edb数据库转Excel模块 1.3.7z”中,包含了一个功能模块,该模块主要用于将edb数据库文件转换成Excel电子表格格式。edb数据库通常是Outlook Express或其他电子邮件服务器使用的数据存储...
在读取Excel数据后,可以使用Java的JDBC库将这些数据插入到关系型数据库中。这可能包括连接数据库、准备SQL语句、执行插入操作以及关闭连接等步骤。 8. **POI API文档**: Apache POI提供了详细的API文档,可以在...