亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

實現Swing的JTables和Excel間的復制和粘貼功能

2019-11-18 14:27:20
字體:
來源:轉載
供稿:網友

  JTable 和 Excel 圖表是常被用在網格或表格中顯示數據。通常,用戶希望輸入到 JTable 的數據已經存在于 Excel 電子表格中。Excel 格式使用在非 Excel 軟件中來實現導入-導出功能。因為如此,java 軟件也應該提供通用的剪貼板功能,例如在 JTable 和 Excel 間復制和粘貼。本文展示了如何使用系統粘貼板在 Java 程序和 Excel 間復制數據。使用這一 Java 技巧中提供的適配器類,只需一行代碼即可添加在 JTables 和 Excel 間復制和粘貼信息的功能。請注重,由于未簽名的 applet 不能使用系統剪貼板,此功能不適用于這些 Java 程序。

當今很多業務應用程序都是使用 Java 開發的,并且以后這種用 Java 開發的應用會更多。而在許多應用程序都使用了 Swing 的 JTable 組件,以類似電子表格的格式顯示數據。假如業務應用程序可以將數據導入 Microsoft Excel 和從 Microsoft Excel 中導出數據,則會為用戶帶來方便,使用戶可以使用無處不在的該電子表格程序的強大功能。此 Java 技巧將幫助您理解系統剪貼板,并使您的 JTable 能夠與 Excel 交互和互操作。您將看到,通過在當前應用程序中僅僅添加另外的一行代碼即可實現這一有用功能的添加。

要實現這一目標,需要做的只是復制這里給出的文件 ExcelAdapter.java,對其進行編譯,并確保您的應用程序可以找到 ExcelAdapter.class 文件;做完后,JTable 就可以與 Excel 進行通話了!我們將向您展示僅通過這一行代碼,如何實現到 Excel 的復制 (Ctrl+C) 和粘貼 (Ctrl+V) 以及從 Excel 進行的復制和粘貼。另外還提供了一個使用 ExcelAdapter 的示例應用程序。

代碼
下面是實際完成此任務的適配器代碼(稱為 ExcelAdapter.java):

import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
import java.awt.datatransfer.*;
import java.util.*;
/**
* ExcelAdapter 實現 JTables 中的復制粘貼
* 剪貼板功能。 適配器所用的剪貼板數據格式
* 與 Excel 所用的剪貼板格式兼容。這提供了
* 支持的 JTables 和 Excel 間的互操作。
*/
public class ExcelAdapter implements ActionListener
{
PRivate String rowstring,value;
private Clipboard system;
private StringSelection stsel;
private JTable jTable1 ;
/**
* Excel 適配器由 JTable 構成,
* 它實現了 JTable 上的復制粘貼
* 功能,并充當剪貼板監聽程序。
*/
public ExcelAdapter(JTable myJTable)
{
jTable1 = myJTable;
KeyStroke copy = KeyStroke.getKeyStroke(KeyEvent.VK_C,ActionEvent.CTRL_MASK,false);
// 確定復制按鍵用戶可以對其進行修改
// 以實現其它按鍵組合的復制功能。
KeyStroke paste = KeyStroke.getKeyStroke(KeyEvent.VK_V,ActionEvent.CTRL_MASK,false);
// 確定粘貼按鍵用戶可以對其進行修改
// 以實現其它按鍵組合的復制功能。
jTable1.registerKeyboardAction(this,"Copy",copy,JComponent.WHEN_FOCUSED);
jTable1.registerKeyboardAction(this,"Paste",paste,JComponent.WHEN_FOCUSED);
system = Toolkit.getDefaultToolkit().getSystemClipboard();
}
/**
* 此適配器運行圖表的公共讀方法。
*/
public JTable getJTable() {return jTable1;}
public void setJTable(JTable jTable1) {this.jTable1=jTable1;}
/**
* 在我們監聽此實現的按鍵上激活這種方法。
* 此處,它監聽復制和粘貼 ActionCommands。
* 包含不相鄰單元格的選擇導致選擇無效,
* 而且此后復制動作無法執行。
* 粘貼的方法是將選定內容的左上角與
* JTable 的當前選定內容的第一個元素對齊。
*/
public void actionPerformed(ActionEvent e)
{
if (e.getActionCommand().compareTo("Copy")==0)
{
StringBuffer sbf=new StringBuffer();
// 檢查以確保我們僅選擇了單元格的
// 相鄰塊
int numcols=jTable1.getSelectedColumnCount();
int numrows=jTable1.getSelectedRowCount();
int[] rowsselected=jTable1.getSelectedRows();
int[] colsselected=jTable1.getSelectedColumns();
if (!((numrows-1==rowsselected[rowsselected.length-1]-rowsselected[0] &&
numrows==rowsselected.length) &&
(numcols-1==colsselected[colsselected.length-1]-colsselected[0] &&
numcols==colsselected.length)))
{
JOptionPane.showMessageDialog(null, "Invalid Copy Selection",
"Invalid Copy Selection",
JOptionPane.ERROR_MESSAGE);
return;
}
for (int i=0;i<numrows;i++)
{
for (int j=0;j<numcols;j++)
{
sbf.append(jTable1.getValueAt(rowsselected[i],colsselected[j]));
if (j<numcols-1) sbf.append(" ");
}
sbf.append("");
}
stsel = new StringSelection(sbf.toString());
system = Toolkit.getDefaultToolkit().getSystemClipboard();
system.setContents(stsel,stsel);
}
if (e.getActionCommand().compareTo("Paste")==0)
{
System.out.println("Trying to Paste");
int startRow=(jTable1.getSelectedRows())[0];
int startCol=(jTable1.getSelectedColumns())[0];
try
{
String trstring= (String)(system.getContents(this).getTransferData(DataFlavor.stringFlavor));
System.out.println("String is:"+trstring);
StringTokenizer st1=new StringTokenizer(trstring,"");
for(int i=0;st1.hasMoreTokens();i++)
{
rowstring=st1.nextToken();
StringTokenizer st2=new StringTokenizer(rowstring," ");
for(int j=0;st2.hasMoreTokens();j++)
{
value=(String)st2.nextToken();
if (startRow+i< jTable1.getRowCount() &&
startCol+j< jTable1.getColumnCount())
jTable1.setValueAt(value,startRow+i,startCol+j);
System.out.println("Putting "+ value+"at
row="+startRow+i+"column="+startCol+j);
}
}
}
catch(Exception ex){ex.printStackTrace();}
}
}
}

示例應用程序
下面是示例應用程序 Frame1.java,它使用 ExcelAdapter 實現 JTable 與 Excel 的兼容。

import java.awt.*;
import javax.swing.*;
public class Frame1 extends Frame
{
BorderLayout borderLayout1 = new BorderLayout();
JTable jTable1 ;
Object[][] data=new Object[4][4];
Object header[]= {"Jan","Feb","Mar","Apr"};
public static void main(String args[])
{
Frame1 myframe=new Frame1();
myframe.setSize(new Dimension(250,250));
myframe.setVisible(true);
}
public Frame1()
{
super();
try
{
jbInit();
}
catch (Exception e)
{
e.printStackTrace();
}
}
private void jbInit() throws Exception
{
for (int i=0;i<4;i++)
for (int j=0;j<4;j++)
data[i][j]=new Integer(i*10+j);
System.out.println("Header length="+header[1]);
jTable1=new JTable(data,header);
jTable1.setCellSelectionEnabled(true);
this.setTitle("Excel Lent JTABLE");
jTable1.setBackground(Color.pink);
this.setLayout(borderLayout1);
this.setSize(new Dimension(400, 300));
this.setBackground(Color.white);
this.add(jTable1, BorderLayout.CENTER);
// 這就是添加復制和粘貼功能的那一行!
ExcelAdapter myAd = new ExcelAdapter(jTable1);
}
}

Excel 的剪貼板格式
Excel 的剪貼板格式非常簡單。它采用制表符分隔同一行上的元素,并用換行符分隔行。這樣,當您復制一組連續的和/或相鄰的單元格時,Excel 只將電子表格數據標記到一個長字符串中,各個單元格值由該字符串內的制表符和換行符分隔。假如所選的單元格不相鄰時怎么辦?很簡單:Excel 不會讓您將所選內容復制到剪貼板。這種行為由本文所說明的適配器模擬,假如所選擇的單元格不相鄰,也不會使您復制數據。在 Excel 中,會彈出一個對話框告訴我們不答應復制;這一行為由適配器再次模擬。

代碼簡單解釋
要使用這一功能,您需要下載 ExcelAdapter.java 文件,對其進行編譯,將示例應用程序中的最后一行添加到您代碼中的某個位置,以激活 JTable 上的適配器。

在適配器中,復制和粘貼功能的激活按鍵都經過了注冊。其后,無論何時鍵入激活的按鍵, actionPerformed 方法就會被調用。假如是復制操作,則所選擇的單元格數據都會為 Excel 進行適當的標記,并寫入系統剪貼板中。假如是粘貼操作,則將系統剪貼板中的數據轉換為字符串形式,并經過分析,根據所選擇的單元格植入 JTables 單元格中。

結論
使用用 Java 編寫的表格的用戶經常希望 Jtables 中的數據與 Excel 中的數據處理方法相似。它并不是編寫代碼來實現每個 JTable 上的復制-粘貼功能,而是更為簡單地編寫通用的適配器,只需添加一行代碼即可將所需功能添加到每個 Jtable 中。此 Java Tip 中提供的適配器正好做到這一點。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲图片制服诱惑| 中文精品99久久国产香蕉| 欧美精品www| 国产成人综合亚洲| 久久人人爽人人爽人人片av高请| 97视频在线免费观看| 色哟哟亚洲精品一区二区| 国产精品美女在线观看| 国产精品视频男人的天堂| 日韩高清电影免费观看完整版| 日韩美女毛茸茸| 91免费综合在线| 亚洲最大在线视频| 国产91精品久| 欧美精品手机在线| 久久国产精品偷| 粉嫩av一区二区三区免费野| 91精品综合视频| 欧美丝袜美女中出在线| 国产自产女人91一区在线观看| 久久久精品一区| 国产精品免费视频久久久| 亚洲国产精品成人精品| 九色精品美女在线| 亚洲成人黄色网址| 日韩国产中文字幕| 久久综合久久88| 亚洲天堂av高清| 日韩欧美在线视频日韩欧美在线视频| 亚洲色图偷窥自拍| 欧美电影在线观看网站| 另类色图亚洲色图| 欧美日韩福利视频| 4438全国亚洲精品在线观看视频| 一区二区三区视频观看| 96pao国产成视频永久免费| 91久久精品国产91久久性色| 欧美精品免费播放| 亚洲高清久久网| 亚洲一区二区三区视频播放| 亚洲老司机av| 国产亚洲一级高清| 97国产精品视频人人做人人爱| 欧美精品亚州精品| 欧美丰满少妇xxxxx| 亚洲欧洲国产一区| 欧美日韩中文在线| 国产精品亚洲精品| 日韩激情av在线免费观看| 日韩精品极品在线观看播放免费视频| 亚洲成人av资源网| 在线性视频日韩欧美| 欧美最猛性xxxxx(亚洲精品)| 欧美国产第二页| 韩国三级日本三级少妇99| 亚洲国产97在线精品一区| www.美女亚洲精品| 日韩国产在线看| 久久九九精品99国产精品| 国产精品视频一区国模私拍| 国产婷婷97碰碰久久人人蜜臀| 亚洲精品白浆高清久久久久久| 91精品国产乱码久久久久久久久| 久久精品国产精品亚洲| 亚洲免费一在线| 亚洲综合中文字幕在线观看| 欧美激情a∨在线视频播放| 日韩在线观看av| 国产精品久久久久久久久免费| 操日韩av在线电影| 国产99久久精品一区二区 夜夜躁日日躁| 欧美精品国产精品日韩精品| 国产不卡av在线免费观看| 久久成人18免费网站| 国产精品视频999| 日韩精品中文字幕在线播放| 欧美色播在线播放| 久久精品国产成人| 国产有码在线一区二区视频| 欧美黄色片在线观看| 中文字幕亚洲第一| 国产精品视频免费在线观看| 久久97久久97精品免视看| 亚洲精品v欧美精品v日韩精品| 精品在线欧美视频| 成人亚洲欧美一区二区三区| 国产精品爱久久久久久久| 午夜精品久久17c| 欧美日韩精品在线观看| 久久久久久久久久久av| 亚洲一区二区在线| 日韩在线观看视频免费| 日韩大陆毛片av| 欧美黄色三级网站| 精品久久香蕉国产线看观看gif| 一区二区三区视频免费在线观看| 成人a视频在线观看| 欧美性xxxx在线播放| 国产成人在线亚洲欧美| 日韩av在线播放资源| 亚洲国产天堂久久综合| 91九色蝌蚪国产| 欧美亚洲激情视频| 国产精品嫩草影院久久久| 北条麻妃一区二区在线观看| 91精品久久久久久久久久久| 久久精品成人欧美大片| 欧美华人在线视频| 亚洲图片在区色| 国产成人鲁鲁免费视频a| 亚洲欧美国产精品专区久久| 精品亚洲va在线va天堂资源站| 在线播放国产一区二区三区| 日韩欧美国产中文字幕| 中文字幕亚洲情99在线| 亚洲欧美另类在线观看| 日韩欧美在线国产| 91高清视频免费| 国产精品久久久久久久一区探花| 伊人久久久久久久久久久久久| 精品久久久国产精品999| 不卡av电影在线观看| 热草久综合在线| 色中色综合影院手机版在线观看| 日韩暖暖在线视频| 亚洲女人天堂av| 国产亚洲欧美日韩一区二区| 亚洲精品久久久久中文字幕二区| 91高潮在线观看| 国产精品第一第二| 久久久91精品| 亚洲精品xxx| 欧美激情欧美狂野欧美精品| 国产福利视频一区| 美日韩精品视频免费看| 国产精品视频午夜| 欧美性xxxxxxxxx| 一本大道香蕉久在线播放29| 91po在线观看91精品国产性色| 日韩av免费看网站| 色婷婷**av毛片一区| 91夜夜未满十八勿入爽爽影院| 黄色成人av网| 亚洲日韩欧美视频一区| 亚洲精品乱码久久久久久金桔影视| 91日本在线视频| 欧美激情xxxxx| 九九九热精品免费视频观看网站| 久久久久久尹人网香蕉| 色狠狠av一区二区三区香蕉蜜桃| 亚洲精品综合久久中文字幕| 8090理伦午夜在线电影| 亚洲福利视频二区| 亚洲欧美制服第一页| 在线免费观看羞羞视频一区二区| 久久影视电视剧凤归四时歌| 国产一区二中文字幕在线看| 狠狠色狠狠色综合日日五| 成人免费观看网址| 51精品在线观看| 揄拍成人国产精品视频| 欧美黑人极品猛少妇色xxxxx| 欧美电影在线观看完整版| 精品小视频在线|