社区
Java EE
帖子详情
poi中文sheet名乱码的问题
dbmaker
2005-10-06 12:46:49
使用poi生成excel表格,中文sheet名出现乱码,请问怎么解决?
...全文
183
1
打赏
收藏
poi中文sheet名乱码的问题
使用poi生成excel表格,中文sheet名出现乱码,请问怎么解决?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
1 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
HERO2008
2005-12-15
打赏
举报
回复
兄弟,试试这个(编码的问题):
workbook.setSheetName(1, "中文", HSSFWorkbook.ENCODING_UTF_16);
poi
最新版本及收集的帮助资料
java_
POI
教程.pdf java的
POI
操作Excel文件.doc
POI
_API帮助文档.chm
poi
-bin-3.9-20121203.tar.gz
poi
帮助.docx
POI
中文
帮助文档.pdf
poi
中文
教程.doc第一章
POI
简介 实际的开发中,表现层的解决方案虽然有多样,但是IE浏览器已成为最多人使用的浏览器,因为大家都用Windows。在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统、银行系统)。或者是:我们已经习惯用Excel打印。 workbook(HSSFWorkbook),一个workbook可以有多个
sheet
(HSSF
Sheet
)组成,一个
sheet
是由多个row(HSSFRow)组成,一个row是由多个cell(HSSFCell)组成。
POI
可以到www.apache.org下载到。实际运行时,需要有
poi
包就可以了。HSSF提供给用户使用的对象在rg.apache.
poi
.hssf.usermodel包中,主要部分包括Excel对象,样式和格式,还有辅助操作。有以下几种对象: HSSFWorkbook excel的文档对象 HSSF
Sheet
excel的表单 HSSFRow excel的行 HSSFCell excel的格子单元 HSSFFont excel字体 HSSFDataFormat 日期格式 在
poi
1.7中才有以下2项: HSSFHeader
sheet
头 HSSFFooter
sheet
尾(只有打印的时候才能看到效果) 和这个样式 HSSFCellStyle cell样式 辅助操作包括 HSSFDateUtil 日期 HSSFPrintSetup 打印 HSSFErrorConstants 错误信息表 以下可能需要使用到如下的类 import org.apache.
poi
.hssf.usermodel.HSSFCell; import org.apache.
poi
.hssf.usermodel.HSSFCellStyle; import org.apache.
poi
.hssf.usermodel.HSSFDataFormat; import org.apache.
poi
.hssf.usermodel.HSSFFont; import org.apache.
poi
.hssf.usermodel.HSSFRow; import org.apache.
poi
.hssf.usermodel.HSSF
Sheet
; import org.apache.
poi
.hssf.usermodel.HSSFWorkbook; import org.apache.
poi
.hssf.util.HSSFColor; 先看
poi
的examples包中提供的最简单的例子,建立一个空xls文件。 import java.io.FileOutputStream; import java.io.IOException; import org.apache.
poi
.hssf.usermodel.HSSFWorkbook; public class ExcelSample1 { public static void main(String[] args) throws IOException { //创建一个excel文件 HSSFWorkbook wb= new HSSFWorkbook(); FileOutputStream fileOut= new FileOutputStream("c:\\workbook.xls"); // FileOutputStream fileOut= new FileOutputStream("c:/workbook.xls"); wb.write(fileOut); fileOut.close(); } } 通过这个例子,我们在c盘下建立的是一个空白的xls文件(不是空文件)。在此基础上,我们可以进一步看其它的例子。 import org.apache.
poi
.hssf.usermodel.*; import java.io.FileOutputStream; import java.io.IOException; public class CreateCells { public static void main(String[] args) throws IOException { HSSFWorkbook wb = new HSSFWorkbook(); //建立新HSSFWorkbook对象 HSSF
Sheet
sheet
= wb.create
Sheet
("new
sheet
"); //建立新的
sheet
对象 HSSFRow row =
sheet
.createRow((short)0); //在
sheet
里创建一行,参数为行号(第一行,此处可想象成数组) HSSFCell cell = row.createCell((short)0); //在row里建立新cell(单元格),参数为列号(第一列) cell.setCellvalue(1); //设置cell的整数类型的值 row.createCell((short)1).setCellvalue(1.2); //设置cell浮点类型的值 row.createCell((short)2).setCellvalue("test"); //设置cell字符类型的值 row.createCell((short)3).setCellvalue(true); //设置cell布尔类型的值 HSSFCellStyle cellStyle = wb.createCellStyle(); //建立新的cell样式 cellStyle.setDataFormat(HSSFDataFormat. getBuiltinFormat("m/d/yy h:mm")); //设置cell样式为定制的日期格式 HSSFCell dCell =row.createCell((short)4); dCell.setCellvalue(new Date()); //设置cell为日期类型的值 dCell.setCellStyle(cellStyle); //设置该cell日期的显示格式 HSSFCell csCell =row.createCell((short)5); csCell.setEncoding(HSSFCell.ENCODING_UTF_16); //设置cell编码解决
中文
高位字节截断 csCell.setCellvalue("
中文
测试_Chinese Words Test"); //设置中西文结合字符串 row.createCell((short)6).setCellType(HSSFCell.CELL_TYPE_ERROR); //建立错误cell FileOutputStream fileOut = new FileOutputStream("workbook.xls"); wb.write(fileOut); fileOut.close(); } } 通过这个例子,我们可以清楚的看到xls文件从大到小包括了HSSFWorkbook HSSF
Sheet
HSSFRow HSSFCell这样几个对象。我们可以在cell中设置各种类型的值。 尤其要注意的是如果你想正确的显示非欧美的字符时,尤其象中日韩这样的语言,必须设置编码为16位的即是HSSFCell.ENCODING_UTF_16,才能保证字符的高8位不被截断而引起编码失真形成
乱码
。 其他测试可以通过参考examples包中的测试例子掌握
poi
的详细用法,包括字体的设置,cell大小和低纹的设置等。需要注意的是
POI
是一个仍然在完善中的公开代码的项目,所以有些功能正在不断的扩充。 感觉上面的操作比较的繁琐,然后就自己写了一个方法。这个方法不需要事先创建row和cell,直接进行cteateCell就可以了,在程序中会自动进行判断,如果不存在的话会创建。 private static void cteateCell(HSSFWorkbook wb,HSSFRow row,short col,short align,String val){ HSSFCell cell = row.createCell(col); cell.setEncoding(HSSFCell.ENCODING_UTF_16); cell.setCellValue(val); HSSFCellStyle cellstyle = wb.createCellStyle(); cellstyle.setAlignment(align); cell.setCellStyle(cellstyle); } 对里面的几个参数的说明: short col 应该是你的cell单元格的位置也就是列号; short align 应该是你的对齐方式; String val 应该是你单元格里面要添加的值; 具体的调用如下: HSSFRow row =
sheet
.createRow((short)1); cteateCell(wb,row,(short)0,HSSFCellStyle.ALIGN_CENTER_SELECTION,"SampleID"); 在上边的例子里我们看到了要设置一个单元格里面信息的格式(例如,要将信息居中)设置的操作如下: HSSFCellStyle cellstyle = wb.createCellStyle(); cellstyle.setAlignment(HSSFCellStyle.ALIGN_CENTER_SELECTION); cell.setCellStyle(cellstyle); 还有我们我们经常会用到的合并单元格,在这里我们也有这样的操作,代码如下:
sheet
.addMergedRegion(new Region(1,(short)1,2,(short)4)); 这里面我们还要介绍一个经常会遇到的
问题
,就是怎么来冻结一个窗口。
poi
也为我们集成了这样的事情了。代码如下:
sheet
.createFreezePane(1,2); 在这里我们需要注意的是 一、 该方法是在一个具体的
sheet
里面来进行操作。 二、 方法createFreezepane;有2个参数。前一个参数代表列;后一个参数代表行。 上边的代码对应的excel文件如下: 我么在画面上看到了明显的两条黑线,这就是冻结的窗口。 然后我们来看一个完整的STRUTS的小例子,在这个例子里面我们要做的事情是要模拟移动公司的网上营业厅里面的一个功能,我们要把一个客户当月的通话记录和各种信息查询出来,并且生成一张excel报表。首先,我们来看一下网上效果的截图。
java excel 导入手机号码(包括对手机的验证)
/** * 此代码是完成从excel导入电话号码,将正确的电话号码保存到set集合中,因为set集合对于重复的值会覆盖,所以达到了去重复的值的用例,并累计了不正确的电话号码的个数,对电话号码进行了验证有效性。所需要的 dom4j-1.6.1.jar;geronimo-stax-api_1.0_spec-1.0.jar;
poi
-3.7-20101029.jar;
poi
-ooxml-3.7-20101029.jar;
poi
-ooxml-schemas-3.7-20101029.jar;xmlbeans-2.3.0.jar; */ public static void main(String[] args) { Long errorMobileTotal=0L; // 保存正确的电话号码 Set
mobileSet = new HashSet
(); try { XSSFWorkbook wb = new XSSFWorkbook("E:/workbook1.xlsx"); XSSF
Sheet
sheet
= wb.get
Sheet
At(0); XSSFRow row = null; XSSFCell cell = null; String mobileStr=""; for (int i = 0; i <=
sheet
.getLastRowNum(); i++) { row =
sheet
.getRow(i); //System.out.print("第" + i + "行共" + row.getLastCellNum() +"列: "); for (int y = 0; y < row.getLastCellNum(); y++) { cell = row.getCell(y); // 设置字段为字符类型 cell.setCellType(XSSFCell.CELL_TYPE_STRING); // 判断储存格的格式 if (cell != null) { // 取得单元格的值 mobileStr = cell.getStringCellValue(); // 对手机号码进行验证身份正确 if(isMobileNO(mobileStr)) { // 保存正确的手机号码 mobileSet.add(mobileStr); System.out.println("号码"+mobileStr+"正确"); } else { // 累计不正确的电话号码的个数 errorMobileTotal++; System.out.println("不正确的电话号码个数:"+errorMobileTotal); System.out.println("号码"+mobileStr+"不正确"); } } // end (cell != null) }// end 遍历当前行 } // end 遍历当前工作单元
sheet
System.out.println("总共的行数:"+ (Long.valueOf(
sheet
.getLastRowNum())+1)); } catch (Exception e) { e.printStackTrace(); } // 因为要去除重复的所以可能有存在替换的字符 System.out.println("不正确的电话号码个数:"+errorMobileTotal); System.out.println("正确的电话号码个数:" + mobileSet.size()); } public static boolean isMobileNO(String mobiles){ Pattern p = Pattern.compile("^(\\+86)*0*((13[0-9])|(15[^4,\\D])|(18[0,5-9]))\\d{8}$"); Matcher m = p.matcher(mobiles); return m.matches(); }
POI
操作Excel导入和导出
在企业级应用开发中,Excel报表是一种最常见的报表需求,
POI
是apache的子项目,目标是处理ole2对象。它提供了一组操纵Windows文档的Java API目前比较成熟的是HSSF接口,处理MS Excel(97-2002)对象。它不象我们仅仅是用csv生成的没有格式的可以由Excel转换的东西,而是真正的Excel对象,你可以控制一些属性如
sheet
,cell等Apache
POI
是Apache软件基金会的开放源码函式库,
POI
提供API给Java程序对Microsoft Office格式档案读和写的功能。结构:HSSF - 提供读写Microsoft Excel格式档案的功能。XSSF - 提供读写Microsoft Excel OOXML格式档案的功能。HWPF - 提供读写Microsoft Word格式档案的功能。HSLF - 提供读写Microsoft Power
Poi
nt格式档案的功能。HDGF - 提供读写Microsoft Visio格式档案的功能。
Java工具包将Excel(xls、xlsx)格式转换为csv格式文件Linux、Window环境均可使用
下载内容包括: doc目录 : java打包好的工具,可以放在任意目录下,执行下方示例的命令完成文件的格式转换及复制操作,对源文件无影响; src和libs目录 :该目录下存放的jar包开放的源码,libs目录存放的jar包包含(commons-collections4-4.1.jar、
poi
-3.17.jar、xmlbeans-2.6.0.jar等) 使用教程 : 1. java -jar FileHelper.jar 源路径 目标路径 源格式 目标格式 0:单
sheet
/1: 多
sheet
2. 示例 : java -jar FileHelper.jar /root/test /root/test1 xlsx csv 0; 3. 支持文件下的内容批量复制到另一个目录 运行环境 : 1. jdk 1.8环境运行 功能详细介绍 : 对Excel类型文件(xls,xlsx)进行批量转换CSV格式,完成文件格式无损转换,在Linux系统,通过view或其他命令查看xls、xlsx文件时会产生
乱码
,使用view查看csv文件不会产生
乱码
,因为csv格式文件是由空格和逗号进行拼接组成的
使用
poi
导出生成Excel,
中文
名
乱码
问题
解决
使用
poi
导出生成Excel,
中文
名
乱码
问题
解决: 使用URLEncoder指定编码格式进行转换。 String
sheet
Name = URLEncoder.encode("
中文
文件
名
", "UTF-8"); 功能:导出列表数据生成excel文件。 Controller: /** * 导出商品类目列表 * * @author Dangelo ...
Java EE
67,513
社区成员
225,879
社区内容
发帖
与我相关
我的任务
Java EE
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
复制链接
扫一扫
分享
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章