============前提加入jar包jxl.jar=========================

// 从数据库导出数据到excel
 public List<Xskh> outPutExcel() {

String url= request.getSession().getServletContext()
     .getRealPath("/")
     + "upload/"; // 创建文件

File dirPath = new File(ctxPath);
   if (!dirPath.exists()) {
    dirPath.mkdir();// 创建文件夹
   }

List<Xskh> list = excelDao.getInfo(" select x from Xskh  ");// 查询数据库导出资料
  try {

WritableSheet sheet = null;
   // 创建excel文件
   WritableWorkbook book = Workbook.createWorkbook(new File(url+"data.xls"));
   // 生成名为“第一页”的工作表,参数0表示这是第一页
   sheet = book.createSheet(" 第一页 ", 0);

// 设置行宽、高
   sheet.getSettings().setDefaultColumnWidth(20);
   sheet.getSettings().setDefaultRowHeight(480);

// 设置字体
   WritableFont font = new WritableFont(WritableFont.ARIAL, 12,
     WritableFont.BOLD, false, UnderlineStyle.NO_UNDERLINE,
     Colour.RED);
   WritableCellFormat wcfF = new WritableCellFormat(font);

// 字体居中
   wcfF.setVerticalAlignment(VerticalAlignment.CENTRE);
   // 自动换行
   wcfF.setWrap(true);

// 在Label对象的构造子中指名单元格位置是第一列第一行(0,0)
   // 以及单元格内容为test
   Label label = new Label(0, 0, "简称 ", wcfF);
   // 将定义好的单元格添加到工作表中
   sheet.addCell(label);
   Label labelcomplay = new Label(1, 0, "公司", wcfF);
   sheet.addCell(labelcomplay);

Label labeltel = new Label(2, 0, "固定电话", wcfF);
   sheet.addCell(labeltel);

Label labelmobile = new Label(3, 0, "移动电话", wcfF);
   sheet.addCell(labelmobile);

Label labelfax = new Label(4, 0, "传真", wcfF);
   sheet.addCell(labelfax);
   Label labeladdr = new Label(5, 0, "地址", wcfF);
   sheet.addCell(labeladdr);
   Label labelsite = new Label(6, 0, "网址", wcfF);
   sheet.addCell(labelsite);

Label labelmail = new Label(7, 0, "邮箱", wcfF);
   sheet.addCell(labelmail);
   Label qq = new Label(8, 0, "qq", wcfF);
   sheet.addCell(qq);
   Label people = new Label(9, 0, "联系人", wcfF);
   sheet.addCell(people);

Label linkbm = new Label(10, 0, "联系人部门", wcfF);
   sheet.addCell(linkbm);
   Label linkejob = new Label(11, 0, "联系人职务", wcfF);
   sheet.addCell(linkejob);
   Label linkphone = new Label(12, 0, "联系人电话", wcfF);
   sheet.addCell(linkphone);

// 所有资料
   for (int i = 0; i < list.size(); i++) {

Label labelad = new Label(0, i + 1, list.get(i).getName());
    sheet.addCell(labelad);
    Label labelmail2 = new Label(1, i + 1, list.get(i).getCompany());
    sheet.addCell(labelmail2);

Label tel = new Label(2, i + 1, list.get(i).getTelephone());
    sheet.addCell(tel);
    Label mobile = new Label(3, i + 1, list.get(i).getMobile());
    sheet.addCell(mobile);
    Label fax = new Label(4, i + 1, list.get(i).getFax());
    sheet.addCell(fax);
    Label addr = new Label(5, i + 1, list.get(i).getAddress());
    sheet.addCell(addr);
    Label site = new Label(6, i + 1, list.get(i).getWww());
    sheet.addCell(site);
    Label mail = new Label(7, i + 1, list.get(i).getEmail());
    sheet.addCell(mail);
    Label q = new Label(8, i + 1, list.get(i).getQq());
    sheet.addCell(q);
    Label peo = new Label(9, i + 1, list.get(i).getLikeme());
    sheet.addCell(peo);
    Label bm = new Label(10, i + 1, list.get(i).getKfPeoBm());
    sheet.addCell(bm);
    Label zw = new Label(11, i + 1, list.get(i).getKfPeoZhiwei());
    sheet.addCell(zw);
    Label linktel = new Label(12, i + 1, list.get(i).getKfPeoTel());
    sheet.addCell(linktel);//创建excel

}

// 写入数据并关闭文件
   book.write();
   book.close();

  String result = download(request, response, url+ "/data.xls", "data.xls");//下载的方法
   if ("unexists".equals(result)) {
    request.setAttribute("msg", "抱歉,文件不存在,请重新导入文件!");
   } else if ("error".equals(result)) {
    request.setAttribute("msg", "抱歉,当前服务器用户过多,请稍后再试!");
   } else {
    request.setAttribute("msg", "数据导出成功!");

}

} catch (Exception e) {
   e.printStackTrace();
   return null;

}
  return list;
 }

---------------------下载的方法------------------

public  String download(HttpServletRequest request,
   HttpServletResponse response, String urlandfile, String fileName)
   throws Exception {
  String msg = null;
  try {
   response.setCharacterEncoding("UTF-8");
   response.setContentType("text/html");
   javax.servlet.ServletOutputStream ou = response.getOutputStream();
   // 路径
   java.io.File file = new java.io.File(urlandfile);

if (!file.exists()) {
    System.out.println(file.getAbsolutePath() + " 文件不能存在!");
    msg = "unexists";
    return msg;
   }

// 读取文件流
   java.io.FileInputStream fileInputStream = new java.io.FileInputStream(
     file);

// 下载文件
   // 设置响应头和下载保存的文件名

response.setContentType("application/x-msdownload");// 弹出下载的框

response.setContentLength((int) file.length());// 下载统计文件大小的进度
   response.setHeader("Content-Disposition", "attachment; filename="
     + fileName);
   // 下载框的信息
   if (fileInputStream != null) {
    int filelen = fileInputStream.available();
    // 文件太大时内存不能一次读出,要循环

byte a[] = new byte[filelen];

fileInputStream.read(a);

ou.write(a);
   }
   fileInputStream.close();

ou.close();

msg = "success";
  } catch (Exception e) {
   e.printStackTrace();
   msg = "error";

}
  // 解决完成后使用一切正常,但是总抛出java.lang.IllegalStateException异常主要是流还存在
  return msg;
 }

java 对excel操作 读取、写入、修改数据;导出数据库数据到excel的更多相关文章

  1. 在ASP.NET中将GridView数据导出到Word、Excel

    在ASP.NET中将GridView数据导出到Word.Excel asp.net,导出gridview数据到Word,Excel,PDF   #region Export to Word, Exce ...

  2. python openpyxl模块实现excel的读取,新表创建及原数据表追加新数据

    当实际工作需要把excel表的数据读取出来,或者把一些统计数据写入excel表中时,一个设计丰富,文档便于寻找的模块就会显得特别的有吸引力,本文对openpyxl模块的一些常见用法做一些记录,方便工作 ...

  3. java导出数据到excel里:直接导出和导出数据库数据

    一.直接导出 package com.ij34.util; import java.io.FileNotFoundException; import java.io.FileOutputStream; ...

  4. Java注解(Annotation)用法:利用注解和反射机制指定列名导出数据库数据

    闲来没事,想了一个应用的例子:用java如何把数据库的数据根据我们指定的某几列,如第2列,第4列,第6列导出来到Excel里? 写代码也是为了应用的,写好的代码更重要的是在于思考.我自己思考了这个示例 ...

  5. 配置ODBC DSN数据源,导出数据库数据到Excel过程记录

    一.前言 工作中我们可能遇到这样的需要:查询数据库中的信息,并将结果导出到Excel文件.这本来没什么,但数据量比较大时,用PLSQL.toad导出Excel会出现内存不足等情况,使用odbc+Mic ...

  6. 2019.06.05 ABAP EXCEL 操作类代码 OLE方式(模板下载,excel上传,内表下载)

    一般使用标准的excel导入方法9999行,修改了标准的excel导入FM 整合出类:excel的 模板下载,excel上传,ALV内表下载功能. 在项目一开始可以SE24创建一个类来供整体开发使用, ...

  7. 导出数据库数据到Excel表

    后台需要将用户信息数据导入到Excel表中提供给相关人员: 首先查询数据就不多说了: 导入Excel表直接亮代码(采用的是jxl的jar包提供的方法): public static File Impo ...

  8. BCP 导入导出数据库数据

    使用 bcp 将数据库迁移到 Azure SQL Database --所有 都是在本机sql上运行--先开启cmdshellEXEC sp_configure 'show advanced opti ...

  9. 接口json数据与数据库数据循环比对校验

    创建测试计划,加载数据库驱动: 线程组: csv配置元件: 注:Filename用的是相对路径,csv文件要与jmeter脚本文件在同一目录 JDBC连接配置: jdbc请求: 用户定义的变量: ht ...

随机推荐

  1. 一个基于PDO的数据库操作类(新) 一个PDO事务实例

    <?php /* * 作者:胡睿 * 日期:2011/03/19 * 电邮:hooray0905@foxmail.com * * 20110319 * 常用数据库操作,如:增删改查,获取单条记录 ...

  2. “-bash: svn: command not found”

    今天升级了Xcode5.界面更加的清爽了,但是在命令行里SVN也失去了作用了. 当我要更新的时候提示:“-bash: svn: command not found” 解决办法: 1:打开Prefere ...

  3. 关于TCP/UDP缓存

    1.修订单个socket的缓冲区大小:通过setsockopt使用SO_RCVBUF来设置接收缓冲区,该参数在设置的时候不会与rmem_max进行对比校验,但是如果设置的大小超过rmem_max的话, ...

  4. BroadcastReceiver应用详解

    今天我们来讲一下Android中BroadcastReceiver的相关知识. BroadcastReceiver也就是“广播接收者”的意思,顾名思义,它就是用来接收来自系统和应用中的广播. 在And ...

  5. 腾讯内部举报信曝光: HR内斗混乱 玩弄求职者

    来自:http://www.guigu.org/news/guigushijie/2013102140759.html 腾讯CEO马化腾正在内部大搞思想整风运动,此时,猎云网独家获得数封来自腾讯内部的 ...

  6. [转]LoadRunner参数化详解

    http://www.cnblogs.com/fnng/archive/2012/06/22/2558900.html 距离上次使用loadrunner 已经有一年多的时间了.初做测试时在项目中用过, ...

  7. ubuntu 挂起唤醒和声音偏小的问题

    自从开始用ubuntu就遇到了声音偏小的问题,一直很让我头疼.还好插上耳机后勉强能用,也就没继续追究了. 可最近发现了一个更加严重的问题挂起后竟然无法唤醒,一直是黑屏的状态,必须强制关机再重启,这就蛋 ...

  8. Quartz使用总结

    废话的前言 以前凭借年轻,凡事都靠脑记.现在工作几年后发现,很多以前看过.用过的东西,再次拿起的时候总觉得记不牢靠."好记性不如烂笔头"应该是某位上了年纪的大叔的切肤之痛(仅次于上 ...

  9. CString类Format()的用法 .xml

    pre{ line-height:1; color:#9f1d66; background-color:#f0f0f0; font-size:16px;}.sysFunc{color:#5d57ff; ...

  10. DOM笔记(十):JavaScript正则表达式

    一.RegExp ECMAScript通过RegExp类型类支持正则表达式,语法和Perl类似: var exp = /pattern/flags; patternb部分是任何简单的或复杂的正则表达式 ...