BufferedReader bufferedReader = null
File file = new File("文档地址+文档名.docx")
if(!file.exists()){
System.out.println("文件不存在")
} else {
bufferedReader = new BufferedReader(new InputStreamReader(new FileInputStream(file), "读取的字符格式(UTF-8或GBK)"))
String lineText = null
while((lineText = bufferedReader.readLine()) != null){
if (linText != null &&!lineText.eq("")){
System.out.println("一次读取一行,一行内容为:" + lineText)
}
}
}
java导出word大致有6种解决方案:1:Jacob是Java-COM Bridge的缩写,它在Java与微软的COM组件之间构建一座桥梁。使用Jacob自带的DLL动态链接库,并通过JNI的方式实现了在Java平台上对COM程序的调用。DLL动态链接库的生成需要windows平台的支持。该方案只能在windows平台实现,是其局限性。
2:Apache POI包括一系列的API,它们可以 *** 作基于MicroSoft OLE 2 Compound Document Format的各种格式文件,可以通过这些API在Java中读写Excel、Word等文件。他的excel处理很强大,对于word还局限于读取,目前只能实现一些简单文件的 *** 作,不能设置样式。
3:Java2word是一个在java程序中调用 MS Office Word 文档的组件(类库)。该组件提供了一组简单的接口,以便java程序调用他的服务 *** 作Word 文档。 这些服务包括: 打开文档、新建文档、查找文字、替换文字,插入文字、插入图片、插入表格,在书签处插入文字、插入图片、插入表格等。填充数据到表格中读取表格数据 ,1.1版增强的功能: 指定文本样式,指定表格样式。如此,则可动态排版word文档。是一种不错的解决方案。
4:iText是著名的开放源码的站点sourceforge一个项目,是用于生成PDF文档的一个java类库。通过iText不仅可以生成PDF或rtf的文档,而且可以将XML、Html文件转化为PDF文件。功能强大。
5:JSP输出样式,该方案实现简单,但是处理样式有点缺陷,简单的导出可以使用。
6:用XML做就很简单了。Word从2003开始支持XML格式,大致的思路是先用office2003或者2007编辑好word的样式,然后另存为xml,将xml翻译为FreeMarker模板,最后用java来解析FreeMarker模板并输出Doc。经测试这样方式生成的word文档完全符合office标准,样式、内容控制非常便利,打印也不会变形,生成的文档和office中编辑文档完全一样。
第一步:如何用POI *** 作Excel@Test
public void createXls() throws Exception{
//声明一个工作薄
HSSFWorkbook wb = new HSSFWorkbook()
//声明表
HSSFSheet sheet = wb.createSheet("第一个表")
//声明行
HSSFRow row = sheet.createRow(7)
//声明列
HSSFCell cel = row.createCell(3)
//写入数据
cel.setCellValue("你也好")
FileOutputStream fileOut = new FileOutputStream("d:/a/b.xls")
wb.write(fileOut)
fileOut.close()
}
第二步:导出指定数据库的所有表
分析:
1:某个数数据库有多少表,表名是什么?―――DataBaseMetadate.getMetadate().getTables(null,null,null,new String[]{Table})- excel的文件名称。
2:对每一个表进行select * *** 作。 - 每一个sheet的名称。
3:分析表结构,rs.getMetadate()ResultSetMedated
4:多个列,列名是什么.- 字段名就是sheet的第一行信息。
5:获取每一行的数据 – 放到sheet第一行以后。
@Test
public void export() throws Exception{
//声明需要导出的数据库
String dbName = "focus"
//声明book
HSSFWorkbook book = new HSSFWorkbook()
//获取Connection,获取db的元数据
Connection con = DataSourceUtils.getConn()
//声明statemen
Statement st = con.createStatement()
//st.execute("use "+dbName)
DatabaseMetaData dmd = con.getMetaData()
//获取数据库有多少表
ResultSet rs = dmd.getTables(dbName,dbName,null,new String[]{"TABLE"})
//获取所有表名 - 就是一个sheet
List<String>tables = new ArrayList<String>()
while(rs.next()){
String tableName = rs.getString("TABLE_NAME")
tables.add(tableName)
}
for(String tableName:tables){
HSSFSheet sheet = book.createSheet(tableName)
//声明sql
String sql = "select * from "+dbName+"."+tableName
//查询数据
rs = st.executeQuery(sql)
//根据查询的结果,分析结果集的元数据
ResultSetMetaData rsmd = rs.getMetaData()
//获取这个查询有多少行
int cols = rsmd.getColumnCount()
//获取所有列名
//创建第一行
HSSFRow row = sheet.createRow(0)
for(int i=0i<colsi++){
String colName = rsmd.getColumnName(i+1)
//创建一个新的列
HSSFCell cell = row.createCell(i)
//写入列名
cell.setCellValue(colName)
}
//遍历数据
int index = 1
while(rs.next()){
row = sheet.createRow(index++)
//声明列
for(int i=0i<colsi++){
String val = rs.getString(i+1)
//声明列
HSSFCell cel = row.createCell(i)
//放数据
cel.setCellValue(val)
}
}
}
con.close()
book.write(new FileOutputStream("d:/a/"+dbName+".xls"))
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)