动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Java教程 ]的信息



本月文章推荐
.parseFloat 方法.
.Java 理论与实践:嗨,我的线程到.
.一个简单的表达式求值类,java.
.java克隆详述.
.用LineNumberReader 提供更好的出.
.学一个简单的JFreeChart使用方法.
.从简单程序看java运行错误.
.如何在恰当的时间处理恰当的bug一.
.SilverStream 应用服务器.
.Java用户界面本地化实例探索.
.[SNAP]实例讲解移动QQ在线平台.
.利用Java技术编写桌面软件基础.
.GetSpecialFolder 方法.
.JTree之间的drag/drop.
.动态Proxy与Java ACL用户访问控制.
.jakarta-log4j的使用(java调试工.
.Java应用程序中的按值传递语义以.
.揭开J2EE集群Cluster的神秘面纱.
.用 JDOM 简化 XML 编程.
.Java中常用的加密算法应用MD5,S.

教你如何使用Java读取Excel文件内容

发表日期:2008-1-5 |



  问题:我能用Java读取一个Excel文件吗?假如能,怎么做?
  
  回答:是的,可以用Java读取Microsoft Excel文件。微软提供了一个Excel的ODBC驱动程序,因此我们就可以使用JDBC和Sun的JDBC-ODBC驱动来读取Excel文件了。
  
  假如你有个Excel文件,名为Book1.xls(译者注:由于原文的例子我没有下载下来,所以我用了自己的例子),并且,该文件中有一个工作表(sheet)名为Sheet1
  
  微软的ODBC驱动程序把工作表中的第一行作为列名(译者注:即字段名),工作表名作为数据库表名。
  
  要通过JDBC访问工作表,我们还必须创建一个新的ODBC数据源,在windows 2000系统上创建数据源的过程如下:
  
  进入“控制面板” --> “治理工具” --> “数据源(ODBC)”,(译者注:打开后选择系统DSN),点击添加,在弹出窗口中选择“Driver do Microsoft Excel(*.xls)”
  
  然后在数据源名处输入你一个名字Book1(译者注:相当于数据库名),然后点击“选择工作簿”,然后找到并选取你的Excel文件
  
  点击确定后,系统数据源列表中会出现你设置的数据源名称,
  
  现在数据表已经在数据源列表里了(译者注:点击确定完成配置)。
  
  (译者注:我的例子中)现在假如我们想挑出test1列中的所有“测试”值,那就需要用以下的SQL查询:
  
  SELECT test1 FROM [Sheet1$] WHERE test1='测试'
  
  要注重的是工作表名后面跟了一个“$”符号,这个符号是不可缺少的。为什么?因为他的前后有方括号,因为“$”是SQL语句中的保留字。Life is never easy(译者注:作者发感慨了)。
  
  下面是例子程序:
  
  import java.sql.Connection;import java.sql.Statement;import java.sql.ResultSet;import java.sql.DriverManager;public class ExcelReader {  public static void main( String[] args ) {    Connection c = null;    Statement stmnt = null;    try {      Class.forName( "sun.jdbc.odbc.JdbcOdbcDriver" );      c = DriverManager.getConnection( "jdbc:odbc:Book1", "", "" );      stmnt = c.createStatement();      String query = "SELECT test1 FROM [Sheet1$] WHERE test1='测试'";      ResultSet rs = stmnt.executeQuery( query );            System.out.println( "查得匹配'测试'的test1的记录为:" );      while( rs.next() ) {        System.out.println( rs.getString( "test1" ) );      }    }    catch( Exception e ) {      System.err.println( e );    }    finally {      try {        stmnt.close();        c.close();      }      catch( Exception e ) {        System.err.println( e );      }    }  }}
  
  在此程序中,主函数main() 建立了一个数据表的连接,并取出符合条件的记录。
  
  (译者注:另外,我这里还有一段程序,是读取所有记录的程序,仅作参考):
  
  import java.sql.Connection;import java.sql.Statement;import java.sql.ResultSet;import java.sql.ResultSetMetaData;import java.sql.DriverManager; public class ExcelReader {   public static void main(String[] args){    Connection connection = null;     try{      Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");      Connection con = DriverManager.getConnection( "jdbc:odbc:Book1","","" );      Statement st = con.createStatement();      ResultSet rs = st.executeQuery( "SELECT * FROM [Sheet1$]" );       ResultSetMetaData rsmd = rs.getMetaData();      int numberOfColumns = rsmd.getColumnCount();       while (rs.next()) {        for (int i = 1; i <= numberOfColumns; i++) {          if(i>1) //用逗号分隔各列   System.out.print(", ");          String columnValue = rs.getString(i);          System.out.print(columnValue);        }        System.out.println("");      }       st.close();      con.close();     } catch(Exception ex) {      System.err.print("Exception: ");      System.err.println(ex.getMessage());    }  }}
  lose();     } catch(Exception ex) {      System.err.print("Exception: ");      System.err.println(ex.getMessage());    }  }}

上一篇:Java新手上路大全(初学者必看) 人气:991
下一篇:java最佳学习途径 人气:391
浏览全部Java的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-7-6 飞天论坛FTBBS ASP v6.3 Build 0
2008-7-6 飞天论坛FTBBS ASP v6.3 Build 0
2008-7-6 飞天论坛FTBBS ASP v6.8 Build 0
2008-7-6 讯息内容管理系统 v2.1
2008-7-6 三五电影程序 v2.0
2008-7-6 神鹰腾讯小说小偷 v3.0
2008-7-6 EasyIDE Framework v1.0 Build 2
2008-7-6 品告CMS系统(电影版) v0.9
2008-7-6 QQ自动登录器 C# 源码 v1.0
2008-7-5 AgileMessenger即时通讯工具 v1.
2008-7-5 GoodCalculator2.0版固件计算器
2008-7-5 RepoName源地址搜索工具 v1.21b
2008-7-5 AgileMessenger即时通讯工具 v1.
2008-7-5 TouchCopy多媒体管理软件 v3.13完
2008-7-5 VideosTone视频铃声 v1.1汉化破解
2008-7-5 TouchPad触摸板 v4.44破解版
2008-7-5 VideosTone破解补丁 v1.0
2008-7-5 Feeds GoogleReader客户端 v0.4.3


  发表评论
姓 名: 验证码:
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報