gpt4 book ai didi

java - 将 jTable 行及其网格线复制到 Excel/Word 文档中

转载 作者:行者123 更新时间:2023-12-01 08:01:38 25 4
gpt4 key购买 nike

是否可以复制 jTable 行并将其粘贴到 Word 文档或带有格式化网格(彩色水平和垂直网格线)的新电子邮件中。如果可以,如何粘贴?

当我从 jTable 复制一行并将其粘贴到 Word 文档中时,Word 将其识别为表格行,但我必须通过添加网格线并为其着色来设置其样式

最佳答案

这是一个非常简单的示例,将一行数据复制到基于 HTML 的表格中。我能够复制任何行并将其作为基于 HTML 的表格粘贴到 Word 中,而不会出现(很多)问题

CopyTable

CopyWord

import java.awt.EventQueue;
import java.awt.Toolkit;
import java.awt.datatransfer.Clipboard;
import java.awt.datatransfer.DataFlavor;
import java.awt.datatransfer.StringSelection;
import java.awt.datatransfer.Transferable;
import java.awt.datatransfer.UnsupportedFlavorException;
import java.awt.event.ActionEvent;
import java.io.InputStream;
import java.io.Reader;
import java.io.StringBufferInputStream;
import java.io.StringReader;
import java.util.ArrayList;
import java.util.Vector;
import javax.swing.AbstractAction;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
import javax.swing.table.DefaultTableModel;

public class CopyTable {

public static void main(String[] args) {
new CopyTable();
}

public CopyTable() {
EventQueue.invokeLater(new Runnable() {
@Override
public void run() {
try {
UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
} catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
ex.printStackTrace();
}

DefaultTableModel model = new DefaultTableModel();
for (int index = 0; index < 26; index++) {
model.addColumn((char) (index + 65));
}

for (int row = 0; row < 26; row++) {
Vector rowData = new Vector();
for (int col = 0; col < 26; col++) {
rowData.add(row + "x" + col);
}
model.addRow(rowData);
}

JTable table = new JTable(model);
table.getActionMap().put("copy", new AbstractAction() {
@Override
public void actionPerformed(ActionEvent e) {
int row = table.getSelectedRow();
StringBuilder sb = new StringBuilder(128);
sb.append("<table border=1 width=100%><tr>");
for (int col = 0; col < table.getColumnCount(); col++) {
sb.append("<td>");
sb.append(table.getValueAt(row, col).toString());
sb.append("</td>");
}
sb.append("</tr></table>");

Clipboard clipboard = Toolkit.getDefaultToolkit().getSystemClipboard();
clipboard.setContents(new HtmlSelection(sb.toString()), null);
}
});

JFrame frame = new JFrame("Testing");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.add(new JScrollPane(table));
frame.pack();
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
});
}

private static class HtmlSelection implements Transferable {

private static ArrayList htmlFlavors = new ArrayList();

static {

try {

htmlFlavors.add(new DataFlavor("text/html;class=java.lang.String"));

htmlFlavors.add(new DataFlavor("text/html;class=java.io.Reader"));

htmlFlavors.add(new DataFlavor("text/html;charset=unicode;class=java.io.InputStream"));

} catch (ClassNotFoundException ex) {

ex.printStackTrace();

}

}

private String html;

public HtmlSelection(String html) {

this.html = html;

}

public DataFlavor[] getTransferDataFlavors() {

return (DataFlavor[]) htmlFlavors.toArray(new DataFlavor[htmlFlavors.size()]);

}

public boolean isDataFlavorSupported(DataFlavor flavor) {

return htmlFlavors.contains(flavor);

}

public Object getTransferData(DataFlavor flavor) throws UnsupportedFlavorException {

if (String.class.equals(flavor.getRepresentationClass())) {

return html;

} else if (Reader.class.equals(flavor.getRepresentationClass())) {

return new StringReader(html);

} else if (InputStream.class.equals(flavor.getRepresentationClass())) {

return new StringBufferInputStream(html);

}

throw new UnsupportedFlavorException(flavor);

}

}
}

这是非常有限的,因为这将简单地使用每个单元格的 toString 方法来获取单元格的值,这意味着单元格值不会根据值类型或应用程序“格式化”要求。您必须自己设计一个解决方案,将单元格值格式化为String

关于java - 将 jTable 行及其网格线复制到 Excel/Word 文档中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24966974/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com