*有关报表一 excel输出到IE中出乱码

news/2024/7/21 3:55:37 标签: excel, ie, 报表, opensource, 文档, weblogic
iews" class="htmledit_views">

用jsp动态输出excel文档和中文乱码问题的解决

最近在网上看到一个用java来操纵excel的open source,在weblogic上试用了一下,觉得很不错,特此向大家推荐一下。

首先去http://www.andykhan.com/jexcelapi/index.html下载最新的JExcelApi,把jxl.jar置于你的classpath中。


写一个javaBean,利用JExcelApi来动态生成excel文档,我这里写一个最简单的,示意性的。复杂的你可能还要查询数据库什么的。

///Test.java///
package com.jagie.test;
import java.io.*;
import jxl.*;
import jxl.write.*;
import jxl.format.*;


import java.util.*;
import java.awt.Color;
public class Test{


  public static void writeExcel(OutputStream os) throws Exception {
    jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(os);
    jxl.write.WritableSheet ws = wwb.createSheet("TestSheet1", 0);
    jxl.write.Label labelC = new jxl.write.Label(0, 0, "我爱中国");
    ws.addCell(labelC);
    jxl.write.WritableFont wfc = new jxl.write.WritableFont(WritableFont.ARIAL,
        20, WritableFont.BOLD, false,
        UnderlineStyle.NO_UNDERLINE, jxl.format.Colour.GREEN);
    jxl.write.WritableCellFormat wcfFC = new jxl.write.WritableCellFormat(wfc);
    wcfFC.setBackground(jxl.format.Colour.RED);
    labelC = new jxl.write.Label(6, 0, "中国爱我",wcfFC);
    ws.addCell(labelC);
    //写入Exel工作表
    wwb.write();
    //关闭Excel工作薄对象
    wwb.close();

  }

//最好写一个这样的main方法来测试一下你的这个class是否写好了。
  public static void main(String[] args)throws Exception{
    File f=new File("kk.xls");
    f.createNewFile();
    writeExcel(new FileOutputStream(f));
  }

}

写一个jsp,来利用Test这个javabean输出excel文档

///test_excel.jsp//

<%@page import="com.jagie.test.Test" %>
<%
response.reset();//保证response的buffer里面没有别的东西。
response.setContentType("application/vnd.ms-excel");
Test.writeExcel(response.getOutputStream());
%>
这样就大功告成了,你用ie访问test_excel.jsp就能在ie里面打开动态生成的excel文档了。一点乱码也没有。

 

我试过好几次,怎么都是直接下载excel~谁能告诉我怎么在IE中打开,且不出乱码的呀


http://www.niftyadmin.cn/n/1425951.html

相关文章

Mysql中日期时间型解析

转载于:https://www.cnblogs.com/Jasxu/p/mysql_date.html

JAVA集合类 (JAVA的容器---List,Map,Set )

Collection├List│├LinkedList│├ArrayList│└Vector│ └Stack└SetMap├Hashtable├HashMap└WeakHashMap 集合有ArrayList,vector.hashmap,linklist,treemap,hashset等多种实现. 为了屏蔽实现差异,java提供了一个Collection(集合)接口,规定必须实现一些公用的方法. 比…

SQLite 数据库获取添加记录后自增长的ID

select last_insert_rowid(); 转载于:https://www.cnblogs.com/Jasxu/p/sqlite_auto.html

Java基本概念:集合类 List/Set/Map...的区别

Collection&#xff1a;List、SetMap&#xff1a;HashMap、HashTable 如何在它们之间选择 一、Array &#xff0c; Arrays Java所有“存储及随机访问一连串对象”的做法&#xff0c;array是最有效率的一种。 1、效率高&#xff0c;但容量固定且无法动态改变。array还有一个缺点…

Mysql常用表管理语句

转载于:https://www.cnblogs.com/Jasxu/p/mysql_common.html

web.xml 配置出错跳转页面

<error-page> <error-code>404</error-code> <location>/404.jsp</location> </error-page> 404.jspFile not found.

Mysql中各种常见数据库存储引擎对比

转载于:https://www.cnblogs.com/Jasxu/p/mysql_data_engine.html

Mysql中常见索引操作

转载于:https://www.cnblogs.com/Jasxu/p/Mysql_index.html