利用jsp把数据导出到Excle【原创】

本文介绍了一种使用JSP页面实现Excel文件导出的方法。通过设置HTTP响应头和使用jxl库来创建并填充Excel工作簿,实现了从JSP页面导出带有数据的工作表的功能。

jsp页面里面只需要:

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@ page import = "java.io.*"%>
<%@ page import = "Excel.*"%>

<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<%
String fname = "excle标题";
OutputStream os = response.getOutputStream();//取得输出流
response.reset();//清空输出流

response.setCharacterEncoding("UTF-8");
fname = java.net.URLEncoder.encode(fname,"UTF-8");
response.setHeader("Content-Disposition","attachment; filename="+ new String(fname.getBytes("UTF-8"),"GBK") + ".xls");
response.setContentType("application/msexcel");//定义输出类型
ivyExcel sw = new ivyExcel();
sw.creatExcel(os);


%>


<html>
<head>
    <base href="<%=basePath%>">
   
    <title>My JSP 'index.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">   
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>

<body>
    This is my JSP page. <br>
</body>
</html>

 

引用的那个导出类:

package Excel;
import java.io.IOException;
import java.io.OutputStream;
import java.sql.Connection;
import java.sql.Date;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;


import jxl.Workbook;
import jxl.write.Label;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;

public class ivyExcel {

public void creatExcel(OutputStream os) throws WriteException,IOException{
  
   WritableWorkbook workbook = Workbook.createWorkbook(os);//创建工作薄
  
    WritableSheet sheet = workbook.createSheet("First Sheet", 0);//创建新的一页
    String[] titles = {"title1","title2","ttle3","title4"};
   
    for (int i=0; i< titles.length;i++){//设置格式和把titile的内容填写上去
     WritableFont bold = new WritableFont(WritableFont.ARIAL , 10, WritableFont.BOLD);
     WritableCellFormat titleFormate = new WritableCellFormat(bold);
     titleFormate.setAlignment(jxl.format.Alignment.CENTRE);
     titleFormate.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);
     sheet.setColumnView(i, 18);
     Label title = new Label(i,0,titles[i],titleFormate);
     sheet.addCell(title);
    }
   
    try{
     Class.forName("com.mysql.jdbc.Driver");
     }
      catch(java.lang.ClassNotFoundException e)
     {
       System.err.print(e.getMessage());
     }
    String url="jdbc:mysql://IP?autoReconnect=true&amp;useUnicode=true&amp;characterEncoding=utf-8";
    try {
     Connection conn=DriverManager.getConnection(url,"root","mm");
     String sql1 = " ";
     String sql2 =

     String sql = sql2+sql1+")";
    
     System.out.println("sql :"+sql);
    
     PreparedStatement prpdStmt = conn.prepareStatement(sql);
     ResultSet rs = prpdStmt.executeQuery();//收集到要的数据了
     int k = 1;//开始设置字体等格式
     WritableFont nobold = new WritableFont(WritableFont.ARIAL , 9, WritableFont.NO_BOLD);
     WritableCellFormat cotentFormate = new WritableCellFormat(nobold);
     cotentFormate.setAlignment(jxl.format.Alignment.CENTRE);
     cotentFormate.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);
     while(rs.next()){
      for (int j =1 ; j<=titles.length;j++){
       Label labelC = new Label(j - 1, k, rs.getString(j),cotentFormate);
       sheet.addCell(labelC);        
      }
      k++;//某一行完成了,过行继续
     }
     rs.close();
     prpdStmt.close();
     conn.close();
    } catch (SQLException e) {
     e.printStackTrace();
    }     
   
    workbook.write();
    workbook.close();
    os.close();
  
}

}

 

<think>嗯,用户想知道如何将JavaFX的TableView数据导出Excel。首先,我得回忆一下JavaFX的相关知识,尤其是TableView的使用。记得TableView是用来展示表格数据的,每个列对应一个TableColumn,数据通常通过ObservableList来绑定。 接下来,导出Excel的话,可能需要用Apache POI库,因为POI是处理Office文档的常用Java库。用户可能需要先添加POI的依赖到项目中,比如Maven的pom.xml或者Gradle的build.gradle里。然后,得从TableView获取数据,遍历每一行,把数据写入Excel的工作表中。 不过,用户可能不太清楚具体步骤,所以步骤要分解清楚。首先,获取TableView中的所有数据,也就是items,这个通常是ObservableList类型的。然后,创建HSSFWorkbook对象,代表一个Excel文件。接着,创建工作表,创建行和单元格,把数据填充进去。最后,将工作簿写入文件输出流,保存成.xls文件。 另外,可能需要注意TableView中的数据可能包含不同类型的字段,比如字符串、数字、日期等,所以在写入Excel时要正确处理这些类型。不过,如果用户的数据都是字符串,可能比较简单,但如果有其他类型可能需要转换。 还有,用户可能希望导出选中的行,而不仅仅是所有数据。这时候需要检查TableView的SelectionModel,获取选中的行,然后处理这些行的数据。不过用户的问题里没有明确提到是否要导出选中行还是全部数据,可能需要分情况说明,或者先以导出全部数据为例,再补充如何导出选中部分。 另外,代码示例可能会有帮助。比如,如何遍历TableView的items,如何获取每一行的数据,如何创建Excel的单元格。要注意TableView的每一列对应的cellValueFactory,可能需要使用getCellData()方法来获取数据,但如果是使用属性值绑定的话,可能直接通过对象的getter方法获取。 还需要考虑异常处理,比如IO异常,以及确保关闭输出流,避免资源泄漏。此外,可能需要提醒用户添加POI的依赖,以及处理可能的依赖冲突或版本问题。 最后,用户可能还需要界面操作,比如通过按钮触发导出操作,所以可能需要结合JavaFX的事件处理,比如在按钮的onAction中调用导出方法。或者提供一个文件选择器让用户选择保存路径。 总结一下,步骤大概是:添加POI依赖,获取TableView数据,创建Excel工作簿,填充数据,保存文件。同时处理可能的数据类型和选中行的情况。给出代码示例,并提示异常处理和文件保存的位置选择。</think>要将JavaFX TableView数据导出Excel文件,可以通过Apache POI库实现。以下是具体步骤和代码示例: ### 一、添加依赖 在pom.xml中添加Apache POI依赖: ```xml <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>5.2.3</version> </dependency> ``` ### 二、实现导出逻辑 ```java public void exportToExcel(TableView<?> tableView, File file) { try (Workbook workbook = new HSSFWorkbook()) { Sheet sheet = workbook.createSheet("Data"); // 添加表头 Row headerRow = sheet.createRow(0); for (int i = 0; i < tableView.getColumns().size(); i++) { TableColumn<?, ?> col = tableView.getColumns().get(i); headerRow.createCell(i).setCellValue(col.getText()); } // 添加数据行 ObservableList<?> items = tableView.getItems(); for (int rowIdx = 0; rowIdx < items.size(); rowIdx++) { Row dataRow = sheet.createRow(rowIdx + 1); Object item = items.get(rowIdx); for (int colIdx = 0; colIdx < tableView.getColumns().size(); colIdx++) { TableColumn<?, ?> col = tableView.getColumns().get(colIdx); Cell cell = dataRow.createCell(colIdx); Object cellValue = col.getCellData(item); cell.setCellValue(cellValue != null ? cellValue.toString() : ""); } } // 写入文件 try (FileOutputStream fos = new FileOutputStream(file)) { workbook.write(fos); } } catch (IOException e) { e.printStackTrace(); } } ``` ### 三、界面调用 ```java @FXML private void handleExport(ActionEvent event) { FileChooser fileChooser = new FileChooser(); fileChooser.getExtensionFilters().add( new FileChooser.ExtensionFilter("Excel Files", "*.xls")); File file = fileChooser.showSaveDialog(tableView.getScene().getWindow()); if (file != null) { exportToExcel(tableView, file); } } ``` ### 注意事项 1. 需要正确处理数据类型的转换(日期/数字等) 2. 若需要导出选中行,可改用`tableView.getSelectionModel().getSelectedItems()` 3. 大数据导出时建议使用SXSSFWorkbook优化内存[^2]
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值