java如何将JTable内容写入excel文件 http://www.javaworld.com/javaworld/javatips/jw-javatip77.html 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 import java.awt.*;import java.awt.event.*;import java.applet.*;import javax.swing.*;import com.util.*;import java.util.*;import javax.swing.table.*;import java.sql.*;public class TestDatabase extends JApplet { boolean isStandalone = false; JButton jButton1 = new JButton(); //触发时间查询按扭 Database db=new Database(); JTable table1 = new JTable(); JScrollPane scroll = new JScrollPane(); JTextField text1 = new JTextField();DefaultTableModel dtm; //定义表格的数据模型 Vector vCdata=null; //定义表的列名(以vector存储) ResultSet rsRow=null; //查询表的数据集合 /**Construct the applet*/ public TestDatabase() { } /**Initialize the applet*/ public void init() { try { jbInit(); userInit(); //自定义的操作都在次方法中 } catch(Exception e) { e.printStackTrace(); } } /**Component initialization*/ private void jbInit() throws Exception { jButton1.setText("jButton1"); jButton1.setBounds(new Rectangle(26, 225, 79, 29)); jButton1.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(ActionEvent e) { jButton1_actionPerformed(e); } }); this.setSize(new Dimension(664, 300)); this.getContentPane().setLayout(null); scroll.setBounds(new Rectangle(12, 24, 644, 189)); text1.setBounds(new Rectangle(16, 271, 365, 22)); this.getContentPane().add(scroll, null); this.getContentPane().add(jButton1, null); // this.getContentPane().add(text1, null); scroll.getViewport().add(table1, null); } /*userInit() 数据表格的初始化*/ public void userInit() { db.connect(); //数据库连接 vCdata=db.getFieldNames("T_REGISTRATION"); //得出列名(vector存储) dtm=new DefaultTableModel(); //定义模式 table1.setModel(dtm); //设定表模式/**for 列出标题烂**/ for(int i=0;i<vCdata.size();i++) dtm.addColumn((String)vCdata.elementAt(i)); rsRow=db.executeQueryTable("T_REGISTRATION"); //得出数据集合 } /**Start the applet*/ public void start() { } /**Stop the applet*/ public void stop() { } /**Destroy the applet*/ public void destroy() { } //static initializer for setting look & feel static { try { //UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName()); //UIManager.setLookAndFeel(UIManager.getCrossPlatformLookAndFeelClassName()); } catch(Exception e) { } }//触发查询事件 void jButton1_actionPerformed(ActionEvent e) { try { while(rsRow.next()) { Vector vRdata=new Vector(); for(int i=0;i<vCdata.size();i++) { vRdata.addElement(rsRow.getString((String)vCdata.elementAt(i))); //列举列数据(vector存储) } dtm.addRow(vRdata); //向表中添家数据 } db.close(); }catch(Exception ei) { System.out.println("error at jButton1_actionPerformed! in TestDatabase" + ei.toString()); } }}这个程序简单的实现了数据表格功能,初始化状态是数据表格只有标题,当click 按扭显示数据。1。在userInit()方法中做了数据表格的初始化,关键的方法:建立表格模型: DefaultTableModel dtm=new DefaultTableModel(),设定表模型:table1.setModel(dtm)设定表格标题:(一切操作可以在模型上做) dtm.addColumn(Vector arg),arg是表的标题,也就是field名字数组得出数据的结果集合:rsRow=db.executeQueryTable("T_REGISTRATION"),这就是一般的数据查询结果哦2。在 void jButton1_actionPerformed(ActionEvent e)中显示数据,关键方法:以行的方式加入数据:dtm.addRow(Vector arg)。3。Jtable有很多的实例化方式,这里采用的是DefaultTableModel模型,对表的操作都可以建立在模型上。4。以后如果更改表中的数据的话可以在模型上修改如:更新3行4列的数据:dtm.setValueAt("bigCat",3,4),也可以table1.setValueAt("bigCat",3,4).得出3行4列数据:Object rs=dtm.getValueAt(3,4);删除第3行数据:dtm.removeRow(3)具体数据表格的展现方式大家可以自己修改设定。别人写的 呵呵~~ 可是我要写入excel文件啊。不是写入jtable 把数据以","分隔开保存。保存的文件后缀是excel文件后缀即可。不过缺点是没有格式信息。 对单例模式的疑惑 新手学JAVA的疑惑!(是不是要学C才能学好JAVA?请前辈们指点!) 急,等待高人回答下,怎么编译JAVA? 求常用类的源码,控制只能输入整数的类,控制只能输入整数或小数的类等,望高手赠送 一个很菜的问题,我是初学者,请高手指点 请教连接SQL Server问题 各位大虾!急!帮忙!关于透明图片的问题,尤请beyond_xiruo兄!高分! 泛型和反射问题 应该如果复制ResultSet数据集合中的一个片段? java学习第三天,老师嘴里一会儿一个类,一会一个子类,父类。偶听不懂,高手解释以下吧! 请教高手,这个错误如何解决?? 请教两个术语的含义--关联、依赖
import java.awt.event.*;
import java.applet.*;
import javax.swing.*;
import com.util.*;
import java.util.*;
import javax.swing.table.*;
import java.sql.*;public class TestDatabase extends JApplet {
boolean isStandalone = false;
JButton jButton1 = new JButton(); //触发时间查询按扭
Database db=new Database();
JTable table1 = new JTable();
JScrollPane scroll = new JScrollPane();
JTextField text1 = new JTextField();DefaultTableModel dtm; //定义表格的数据模型
Vector vCdata=null; //定义表的列名(以vector存储)
ResultSet rsRow=null; //查询表的数据集合 /**Construct the applet*/
public TestDatabase() {
}
/**Initialize the applet*/
public void init() {
try {
jbInit();
userInit(); //自定义的操作都在次方法中
}
catch(Exception e) {
e.printStackTrace();
}
}
/**Component initialization*/
private void jbInit() throws Exception {
jButton1.setText("jButton1");
jButton1.setBounds(new Rectangle(26, 225, 79, 29));
jButton1.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(ActionEvent e) {
jButton1_actionPerformed(e);
}
});
this.setSize(new Dimension(664, 300));
this.getContentPane().setLayout(null);
scroll.setBounds(new Rectangle(12, 24, 644, 189));
text1.setBounds(new Rectangle(16, 271, 365, 22));
this.getContentPane().add(scroll, null);
this.getContentPane().add(jButton1, null);
// this.getContentPane().add(text1, null);
scroll.getViewport().add(table1, null);
} /*userInit() 数据表格的初始化*/
public void userInit()
{
db.connect(); //数据库连接
vCdata=db.getFieldNames("T_REGISTRATION"); //得出列名(vector存储)
dtm=new DefaultTableModel(); //定义模式
table1.setModel(dtm); //设定表模式/**for 列出标题烂**/
for(int i=0;i<vCdata.size();i++)
dtm.addColumn((String)vCdata.elementAt(i)); rsRow=db.executeQueryTable("T_REGISTRATION"); //得出数据集合 } /**Start the applet*/
public void start() {
}
/**Stop the applet*/
public void stop() {
} /**Destroy the applet*/
public void destroy() {
}
//static initializer for setting look & feel
static {
try {
//UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
//UIManager.setLookAndFeel(UIManager.getCrossPlatformLookAndFeelClassName());
}
catch(Exception e) {
}
}//触发查询事件
void jButton1_actionPerformed(ActionEvent e)
{ try
{ while(rsRow.next())
{
Vector vRdata=new Vector();
for(int i=0;i<vCdata.size();i++)
{
vRdata.addElement(rsRow.getString((String)vCdata.elementAt(i))); //列举列数据(vector存储)
}
dtm.addRow(vRdata); //向表中添家数据
}
db.close();
}catch(Exception ei)
{
System.out.println("error at jButton1_actionPerformed! in TestDatabase" + ei.toString());
} }
}这个程序简单的实现了数据表格功能,初始化状态是数据表格只有标题,当click 按扭显示数据。1。在userInit()方法中做了数据表格的初始化,关键的方法:
建立表格模型: DefaultTableModel dtm=new DefaultTableModel(),
设定表模型:table1.setModel(dtm)
设定表格标题:(一切操作可以在模型上做) dtm.addColumn(Vector arg),arg是表的标题,也就是field名字数组
得出数据的结果集合:rsRow=db.executeQueryTable("T_REGISTRATION"),这就是一般的数据查询结果哦2。在 void jButton1_actionPerformed(ActionEvent e)中显示数据,关键方法:
以行的方式加入数据:dtm.addRow(Vector arg)。3。Jtable有很多的实例化方式,这里采用的是DefaultTableModel模型,对表的操作都可以建立在模型上。4。以后如果更改表中的数据的话可以在模型上修改如:
更新3行4列的数据:dtm.setValueAt("bigCat",3,4),也可以table1.setValueAt("bigCat",3,4).
得出3行4列数据:Object rs=dtm.getValueAt(3,4);
删除第3行数据:dtm.removeRow(3)
具体数据表格的展现方式大家可以自己修改设定。别人写的 呵呵~~
不过缺点是没有格式信息。