应朋友要求,写了一个小工具,主要就是实现下面的要求:

		
				  1 import java.util.LinkedList;
  2 
  3 import org.eclipse.swt.SWT;
  4 import org.eclipse.swt.events.SelectionAdapter;
  5 import org.eclipse.swt.events.SelectionEvent;
  6 import org.eclipse.swt.layout.FormAttachment;
  7 import org.eclipse.swt.layout.FormData;
  8 import org.eclipse.swt.layout.FormLayout;
  9 import org.eclipse.swt.widgets.Button;
 10 import org.eclipse.swt.widgets.Display;
 11 import org.eclipse.swt.widgets.Label;
 12 import org.eclipse.swt.widgets.Shell;
 13 import org.eclipse.swt.widgets.Text;
 14 
 15 public class FormatSqlResult {
 16 
 17     private Text text;
 18 
 19     protected Shell shell;
 20 
 21     /**
 22      * Launch the application
 23      * 
 24      * @param args
 25      */
 26     public static void main(String[] args) {
 27         try {
 28             FormatSqlResult window = new FormatSqlResult();
 29             window.open();
 30         } catch (Exception e) {
 31             e.printStackTrace();
 32         }
 33     }
 34 
 35     /**
 36      * Open the window
 37      */
 38     public void open() {
 39         final Display display = Display.getDefault();
 40         createContents();
 41         shell.open();
 42         shell.layout();
 43         while (!shell.isDisposed()) {
 44             if (!display.readAndDispatch())
 45                 display.sleep();
 46         }
 47     }
 48 
 49     /**
 50      * Create contents of the window
 51      */
 52     protected void createContents() {
 53         shell = new Shell();
 54         shell.setLayout(new FormLayout());
 55         shell.setSize(631, 414);
 56         shell.setText("FormatSqlResult");
 57 
 58         text = new Text(shell, SWT.V_SCROLL | SWT.MULTI | SWT.H_SCROLL | SWT.BORDER);
 59         final FormData fd_text = new FormData();
 60         fd_text.bottom = new FormAttachment(100, -34);
 61         fd_text.right = new FormAttachment(100, -5);
 62         fd_text.left = new FormAttachment(0, 0);
 63         fd_text.top = new FormAttachment(0, 0);
 64         text.setLayoutData(fd_text);
 65         final Button formatButton = new Button(shell, SWT.NONE);
 66         formatButton.addSelectionListener(new SelectionAdapter() {
 67             public void widgetSelected(SelectionEvent e) {
 68                 String str = text.getText();
 69                 if (str != null && str.length() > 0) {
 70                     text.setText(getSpaceText(str.replaceAll("\r", "")));
 71                     text.selectAll();
 72                 }
 73 
 74             }
 75         });
 76         final FormData fd_formatButton = new FormData();
 77         fd_formatButton.left = new FormAttachment(0, 286);
 78         fd_formatButton.right = new FormAttachment(100, -287);
 79         fd_formatButton.top = new FormAttachment(100, -26);
 80         fd_formatButton.bottom = new FormAttachment(100, -4);
 81         formatButton.setLayoutData(fd_formatButton);
 82         formatButton.setText("Format");
 83 
 84         final Label label = new Label(shell, SWT.NONE);
 85         final FormData fd_label = new FormData();
 86         fd_label.top = new FormAttachment(100, -19);
 87         fd_label.left = new FormAttachment(100, -130);
 88         fd_label.bottom = new FormAttachment(100, -4);
 89         fd_label.right = new FormAttachment(100, -5);
 90         label.setLayoutData(fd_label);
 91         label.setText("版权所有:交口称赞");
 92 
 93         final Label formatsqlresult10Label = new Label(shell, SWT.NONE);
 94         final FormData fd_formatsqlresult10Label = new FormData();
 95         fd_formatsqlresult10Label.top = new FormAttachment(100, -19);
 96         fd_formatsqlresult10Label.right = new FormAttachment(0, 180);
 97         fd_formatsqlresult10Label.bottom = new FormAttachment(100, -4);
 98         fd_formatsqlresult10Label.left = new FormAttachment(0, 5);
 99         formatsqlresult10Label.setLayoutData(fd_formatsqlresult10Label);
100         formatsqlresult10Label.setText("FormatSqlResult version 1.5");
101     }
102 
103     public String getSpaceText(String allStr) {
104         String[] strs = allStr.split("\n");
105         String lineStr;
106         int row = -1;
107         if (strs != null && strs.length > 0) {
108             lineStr = strs[0];
109             String[] lineStrs = lineStr.split("\t");
110             row = lineStrs.length;
111         }
112         int[] max = new int[row];
113         for (int i = 0; i < max.length; i++) {
114             max[i] = -1;
115         }
116         LinkedList all = new LinkedList();
117         for (int i = 0; i < row; i++) {
118             LinkedList list = new LinkedList();
119             all.add(list);
120         }
121         for (int i = 0; i < strs.length; i++) {
122             lineStr = strs[i];
123             String[] lineStrs = lineStr.split("\t");
124             for (int j = 0; j < lineStrs.length; j++) {
125                 int length = lineStrs[j].length();
126                 if (length > max[j]) {
127                     max[j] = length;
128                 }
129                 ((LinkedList) all.get(j)).add(lineStrs[j]);
130             }
131         }
132 
133         StringBuffer sb = new StringBuffer();
134         int line = ((LinkedList) all.get(0)).size();
135         for (int i = 0; i < line; i++) {
136             for (int j = 0; j < all.size(); j++) {
137                 String str = (String) ((LinkedList) all.get(j)).get(i);
138                 int length = max[j] - str.length() + 1;
139                 sb.append(str);
140                 for (int k = 0; k < length; k++) {
141                     sb.append(" ");
142                 }
143             }
144             sb.append("\n");
145         }
146         return sb.toString();
147     }
148 
149 }
150 
		
				
已制作成exe,可以双击执行,只支持Windows,为了兼容jdk版本,没敢用泛型。
		下载:FormatSqlResult1.rar
	posted on 2007-08-09 11:02 
交口称赞 阅读(1758) 
评论(2)  编辑  收藏  所属分类: 
Eclipse RCP SWT 、
java相关