我正在尝试将JTable导出到Excel文件。 为此,请使用apache POI-SS和apache POI-XSSF。 首先,我使用sax解析器解析xml文件,并将其trnsform转换为JTable,然后单击“导出”按钮,我想将JTable导出为ex​​cel。我创建了2个类,第一个类解析xml文件并创建一个Jtable和第二个用于Excel导出。

我的问题是excel文件,它仅包含2个元素:第一行包含200000,第二行包含100000 ...我试图找到问题所在,但徒劳无功。

这是“ JTable_create”类:

package jtable_excel11;

import java.awt.BorderLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Vector;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;

public class JTable_create {

public static Vector<Vector> rowData = new Vector<Vector>();
public static Vector<String> rowOne = new Vector<String>();
public static Vector<String> columnNames = new Vector<String>();
public static void main(String[] args) {

try {

SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser saxParser = factory.newSAXParser();

DefaultHandler handler;
handler = new DefaultHandler() {
boolean bstaff = false;
boolean bfname = false;
boolean blname = false;
boolean bnname = false;
boolean bsalary = false;
private int i;

public void startElement(String uri, String localName,String qName,
Attributes attributes) throws SAXException {

System.out.println("Start Element :" + qName);

if (qName.equalsIgnoreCase("staff"))
{
rowOne = new Vector<String>();
bstaff = true;
}

if (qName.equalsIgnoreCase("FIRSTNAME")) {
bfname = true;
}

if (qName.equalsIgnoreCase("LASTNAME")) {
blname = true;
}

if (qName.equalsIgnoreCase("NICKNAME")) {
bnname = true;
}

if (qName.equalsIgnoreCase("SALARY")) {
bsalary = true;
}

}

public void endElement(String uri, String localName,
String qName) throws SAXException {

System.out.println("End Element :" + qName);
if ("staff".equals(qName)){
rowData.addElement(rowOne);
System.out.println("pffffffffff");
};

}



@Override
public void characters(char ch[], int start, int length)  {

if (bfname) {
String s = new String(ch, start, length);
rowOne.addElement(s);
System.out.println("First Name : " + new String(ch, start, length));

bfname = false;

}

if (blname) {
rowOne.addElement (new String(ch, start, length));
System.out.println("Last Name : " + new String(ch, start, length));
blname = false;

}

if (bnname) {
rowOne.addElement (new String(ch, start, length));
System.out.println("Nick Name : " + new String(ch, start, length));
bnname = false;

}

if (bsalary) {
rowOne.addElement (new String(ch, start, length));
System.out.println("Salary : " + new String(ch, start, length));
bsalary = false;

}

System.out.println("longueur" + rowOne.size());
}
};

saxParser.parse("file.xml", handler);
JFrame frame = new JFrame();
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
columnNames.addElement("firstname");
columnNames.addElement("lastname");
columnNames.addElement("nickname");
columnNames.addElement("salary");

DefaultTableModel model = new DefaultTableModel(rowData, columnNames);
final JTable table = new JTable(model);


JScrollPane scrollPane = new JScrollPane(table);

JButton export = new JButton("Export");
export.addActionListener(new ActionListener(){
public void actionPerformed(ActionEvent evt){
try {
Escel1 exp = new Escel1();
exp.exportTable(table, new File("C:\\Documents and              Settings\\Adm\\Bureau\\result.xlsx"));
} catch (IOException ex)  {
System.out.println(ex.getMessage());
ex.printStackTrace();
}
}
});

frame.getContentPane().add("South", export);
frame.pack();
frame.setVisible(true);

frame.add(scrollPane, BorderLayout.CENTER);
frame.setSize(300, 150);
frame.setVisible(true);
System.out.println("Fini!");

} catch (Exception e) {
e.printStackTrace();
}

}

}

第二类称为“ Excel1”,其内容如下:

package jtable_excel11;


import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import javax.swing.JTable;
import javax.swing.table.TableModel;


import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;


public class Excel1 {



public Excel1() {}

public void exportTable(JTable table, File file) throws IOException {


System.out.println(" c bon !");

XSSFWorkbook workbook = new XSSFWorkbook();
XSSFSheet sheet = workbook.createSheet("Sample sheet");

System.out.println(" workbook crée");
TableModel model= table.getModel();
HashMap<String, Object[]> data = new HashMap<String, Object[]>();

for(int i=0; i<model.getRowCount(); i++){
for(int j=0; j< model.getColumnCount(); j++){


data.put(i+"",new Object[]{model.getValueAt(i,j).toString()+"\t"});
System.out.println(model.getValueAt(i,j));
System.out.println(i);
System.out.println(j);


}
//data.put("\n");


}

Set<String> keyset = data.keySet();
int rownum = 0;
for (String key : keyset) {
Row row = sheet.createRow(rownum++);
Object[] objArr = data.get(key);
int cellnum = 0;
for (Object obj : objArr) {
Cell cell = row.createCell(cellnum++);
if (obj instanceof Date)
cell.setCellValue((Date) obj);
else if (obj instanceof Boolean)
cell.setCellValue((Boolean) obj);
else if (obj instanceof String)
cell.setCellValue((String) obj);
else if (obj instanceof Double)
cell.setCellValue((Double) obj);
}
}

try {
FileOutputStream out = new FileOutputStream(file);
workbook.write(out);
out.close();
System.out.println("Excel written successfully..");

}  catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}

}
}

这是我的Xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<company>
<staff >
<firstname>yong</firstname>
<lastname>mook kim</lastname>
<nickname>mkyong</nickname>
<salary>100000</salary>
</staff>
<staff >
<firstname>low</firstname>
<lastname>yin fong</lastname>
<nickname>fong fong</nickname>
<salary>200000</salary>
</staff>
</company>

在excel文件中,我只有2行,分别包含200000和100000。

知道我该如何解决吗? 提前致谢

===============>>#1 票数:0

我认为您可以通过将JTable导出为简单的filtype来导出它:“。csv” Excel可以简化它。

一个简单的例子是

kevin,johnson,49
julia,roberts,56

我认为您正在使用JTable作为表而不是树(XML是树的类型)

祝好运

  ask by IMIDEV translate from so

未解决问题?本站智能推荐:

1回复

将行导出到Excel时如何替换默认的Jtable列值-Java

我正在将数据从jtable导出到excel,我该如何设置imagePath字符串以在excel列中替换最后一个jtable列。 在这种情况下,最后一列输出jlabel模型,而不是输出图像路径。 我有一种提取图像路径的方法,我想用新数据替换该列,该数据是图像路径字符串,并且存储在“ imag
2回复

将JTable写入Excel

我打算将JTable的内容移动到Microsoft Excel工作表中。 Excel工作表应具有一些格式规范。 例如,如果列的值为“A”,则应为绿色。 如果它是'B'红色。 我处于分析阶段。 我应该使用哪个罐子? 数据不是很大。性能不是一个大问题。
2回复

复选框在JTable中无法正常工作/不可编辑

这个类是用6列创建jtable,最后一个包含布尔复选框。 我在getColumnClass中指定了它。 我不能取消选中/选中这些框,它们是不可编辑的。 我怀疑类MyTableModel中的方法setValueAt和getValueAt是不正确的,但无法理解它。 请帮忙。 以下是我向您展
2回复

apache poi:将jtable保存到文件中

我最近开始使用java,当我需要从jTable开始创建一个excel文件时,我遇到了apache poi库的一些问题。 我已经阅读了许多线程,并提出了一些不起作用的代码(即使这很简单,有许多例子,这让我看起来更加愚蠢)而且我希望有人可以帮助我。 所以这里是问题: a)为什么写入
1回复

使用自定义TableCellRenderer导出JTable

我有一个JTable ,它使用TableCellRenderer根据其值为某些单元格的背景着色。 我需要将此表格导出为具有相同单元格格式的excel文件。 这是我目前在JTable看到的内容的一部分。 是否必须在Apache POI中复制渲染器后面的所有逻辑才能获得相同的结果
1回复

将数据从JTable导入Excel

我有代码将数据从JTable导入Excel,如下所示: } 但是,当打开文件“Hasil.xlsx”时总是出错。 所以,那个文件无法打开。 我不知道为什么这样。 谢谢
3回复

EDITED将JTable写入Excel

我正在尝试将我的JTable导出到Excel文件。 列和行名称都很好,但我在JTable中添加的所有信息都没有写入。 我尝试了System.out.println() ,它除了列名和行名之外还打印了Null值。 我试图从谷歌谷歌得到答案,但经过2个小时的阅读和尝试,仍然没有进展。 我脑子
1回复

将jTable选择导出到excel并打开excel

我有一个包含很多记录的jtable;我需要在jTable中选择一些记录并将其与所选列的jTable Header一起输出到excel.excel在导出时应随所选数据一起自动打开。 谢谢
1回复

将Java Swing JTable标头导出到Excel

在我的应用程序中,我已经将表内容导出到Excel,但是结果不包括表头。 想知道如何将JTable导出到Excel中包括表头吗? 我尝试了几种方法,但是在excel中仍然看不到表头​​,以下是我的代码:
1回复

使用HTML标签将Swing JTable导出到Excel

如何导出带有颜色的JTable来表现出色? 由于包含了HTML标签,因此excel无法正确呈现表格,因此只能查看HTML标签。