zsh_root
2024-01-02 7b595546af704983dbafcd0d385c8768ddacefc2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
package PbuliClass;
import java.awt.Color;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.sql.ResultSet;
import javax.swing.JFileChooser;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.filechooser.FileNameExtensionFilter;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
import DataBase.DatabaseManagement;
import Frame.AnchorManage;
import Judge.JugeNumber;
import Method.GetNowTime;
import anchor.Anchor_Dell;
import tag.Tag_Dell;
import tag.Tag_Into_Database;
 
/**±í¸ñµ¼Èëµ¼³öÀà*/
 
public class ImExport {
    HSSFWorkbook wb = null;//´´½¨EXCEL¶ÔÏó
    InputStream ins=null;    //ÊäÈëÁ÷
    POIFSFileSystem pfs=null;
    HSSFSheet sheet=null ;//ÉêÃ÷±íµ¥
    int num=0;//±íµ¥ÖеÄÐÐÊý
    HSSFRow hssfRow=null;//ÐжÔÏó
    File file=null;
    File saveFile=null;
    String outName;//µ¼³öÎļþµÄÃû³Æ
    JFileChooser chooser=null;// ´´½¨ÎļþÑ¡ÔñÆ÷
    FileNameExtensionFilter filter;//Îļþ¹ýÂËÆ÷
    int option ;
    dataToExcel toexcel;//Êý¾ÝתΪexcelÊä³ö
 
 
    public ImExport() {//¹¹Ôì·½·¨
        chooser = new JFileChooser("./savefile/");        
        filter=new FileNameExtensionFilter("Excel", "xls");
        //»ñÈ¡jar°üλÖã¬ÉèÖÃJFileChooserµ±Ç°Â·¾¶
 
    }
 
    /**µ¼³ö±í¸ñ·½·¨*/ 
    public void export(JPanel jpan,String sql) {       
        chooser.setFileFilter(filter);//Ìí¼ÓÎļþ¹ýÂËÆ÷    
        option = chooser.showSaveDialog(jpan);// Èç¹ûÈ·¶¨Ôò·µ»Ø0£¬È¡Ïû»ò¹Ø±Õ·µ»Ø1                
        if (option == JFileChooser.APPROVE_OPTION){
            //Êý¾Ý±íµÄÐÐÊý
            int size=OutButton.getSize();            
            if(size >65535) {
 
                double j=size/65535;                        
                int maxPageNumber=(int) Math.ceil(j)+1;
                for(int i=1;i<maxPageNumber+1;i++) {                            
                    int k=65535;
                    String a=String.valueOf(i*k-k);                            
                    String newsql=sql+" limit "+a+","+k;    
                    outName=getFile().getAbsolutePath()+i+".xls";//µ¼³öµÄÎļþÃû×ÖĬÈÏΪexcelÎļþ
                    toexcel=new dataToExcel();
                    try {
                        toexcel.toExcel(newsql, outName, "±êÇ©Áбí");//µ÷Óõ¼³öÎļþ·½·¨                        
                    } catch (Exception e2) {                    
                        e2.printStackTrace();
                    }
 
                    double k1=100/maxPageNumber;
                    OutButton .getProgressBar().setValue((int)Math.ceil(k1)*i);
                }
                OutButton .getProgressBar().setValue(100);
                OutButton .getProgressBar().setBackground(Color.green);
                ShowMessage.zidingyi_24("×ܹ²³É¹¦µ¼³ö"+maxPageNumber+"¸ö±í¸ñ£¡");
 
            } else {
                outName=getFile().getAbsolutePath()+".xls";//µ¼³öµÄÎļþÃû×ÖĬÈÏΪexcelÎļþ
                toexcel=new dataToExcel();
                try {
                    toexcel.toExcel(sql, outName, "±êÇ©Áбí");//µ÷Óõ¼³öÎļþ·½·¨                        
                } catch (Exception e2) {                    
                    e2.printStackTrace();
                }
                OutButton .getProgressBar().setValue(100);
                OutButton .getProgressBar().setBackground(Color.green);
                ShowMessage.zidingyi(outName+"µ¼³ö³É¹¦£¡");
            }        
 
        }
 
    }
 
    /**»ñÈ¡±£´æÎļþµÄ·½·¨*/
    public File getFile() {
        if(file==null) {
            file=chooser.getSelectedFile();//»ñȡѡÖеÄÎļþ 
        }
        return file;
    }    
 
 
    /**»ñÈ¡±íµ¥¶ÔÏóµÄ·½·¨*/
    public  HSSFSheet getSheet(File file) {// Sheet(ÊõÓ¹¤×÷±í)¾ÍÊÇExcel±í¸ñ×óϽǵÄSheet1,Sheet2,Sheet3µ«ÔÚ³ÌÐòÖÐSheetµÄϱêÊÇ´Ó0¿ªÊ¼
 
        if(wb == null) {
            try {
                ins = new FileInputStream(file);
                try {
                    pfs=new POIFSFileSystem(ins);//Îļþϵͳ¿É½ÓÊÜÒ»¸öÊäÈëÁ÷
                } catch (IOException e) {                    
                    e.printStackTrace();
                }
            } catch (FileNotFoundException e) {                
                e.printStackTrace();
            }            
            try {
                wb = new HSSFWorkbook(pfs);
                sheet=wb.getSheetAt(0);//»ñÈ¡µÚÒ»ÕÅ±íµ¥
                //                num= sheet.getLastRowNum();//»ñÈ¡µÚÒ»ÕÅ±íµ¥ÖеÄÐÐÊý
                //                hssfRow=sheet.getRow(num);//»ñȡÿÐжÔÏó
            } catch (IOException e) {                
                e.printStackTrace();
            } 
 
        } 
        return sheet;
 
    }
 
 
 
    /**¹Ø±ÕÊý¾ÝÁ÷µÄ·½·¨*/
    public void getClose() {
        try {
            wb.close();
        } catch (IOException e) {                
            e.printStackTrace();
        }
        try {
            pfs.close();
        } catch (IOException e) {                
            e.printStackTrace();
        }
        try {
            ins.close();
        } catch (IOException e) {                
            e.printStackTrace();
        }
 
    }
 
    /**±êÇ©±í¸ñµ¼ÈëÊý¾Ý¿âµÄ·½·¨*/
    public void excelTagToMysql(JPanel jpan) {    
 
 
        String power="100";
        String zaixian="ÔÚÏß";
        chooser.setFileFilter(filter);//Ìí¼ÓÎļþ¹ýÂËÆ÷
        option=chooser.showOpenDialog(jpan);//ÏÔʾѡÔñÎļþ¶Ô»°¿ò
        if(option==JFileChooser.APPROVE_OPTION) {//Èç¹ûÓû§Ñ¡ÔñµÄÊÇ¡°´ò¿ª¡±°´Å¥
            file=chooser.getSelectedFile();//»ñȡѡÖеÄÎļþ    
            num= getSheet(file).getLastRowNum();//»ñÈ¡µÚÒ»ÕÅ±íµ¥ÖеÄ×ÜÐÐÊý
            //±éÀúrow                
            for(int rowNum=1;rowNum <= num;rowNum++) {                    
                String tag_id=String.valueOf(getSheet(file).getRow(rowNum).getCell(1)).substring(0,4);//±êÇ©ID
                String tag_state=String.valueOf(getSheet(file).getRow(rowNum).getCell(2));//±êÇ©°ó¶¨¶ÔÏó
                String tag_posz=String.valueOf(getSheet(file).getRow(rowNum).getCell(3));//±êÇ©¸ß¶È
                String tag_pinglv=String.valueOf(getSheet(file).getRow(rowNum).getCell(4));//±êǩƵÂÊ
                String tag_sudu=String.valueOf(getSheet(file).getRow(rowNum).getCell(5));//±êÇ©ËÙ¶È
 
 
                //Èç¹û±êǩ״̬Ϊ¿ÕÔò¸³ÖµÎª·ñ
                if(tag_state=="null") {
                    tag_state="δ°ó¶¨";                        
                }
 
                if(tag_posz=="null") {
                    tag_posz="150";                        
                }
 
 
                if(tag_pinglv=="null") {
                    tag_pinglv="1";                        
                }
 
                if(tag_sudu=="null") {
                    tag_sudu="1000";                        
                }
 
 
                // Ö´ÐÐSQL²éѯÓï¾ä»ñµÃµÄ½á¹û¼¯Èç¹û´æÔÚÖØ¸´±êǩɾ³ýÔ­À´±êÇ©
                ResultSet haveTag = DatabaseManagement.query("select * from tb_tag where tag_id='" + tag_id.trim()+ "'");
                try {
                    if (haveTag.next()) {// ½á¹û¼¯ÖбêÇ©IDÓг¬¹ýÒ»ÌõµÄ¼Ç¼
                        String deleteSql="DELETE FROM tb_tag WHERE tag_id='"+tag_id.trim()+"'";
                        DatabaseManagement.update(deleteSql);// É¾³ý±êÇ©ÐÅÏ¢
                    }    
                } 
                catch (Exception er) {
                    er.printStackTrace();
                }    
 
 
 
                Tag_Into_Database.insert_all_Tag_info_dabase(tag_id, tag_state, power, zaixian,tag_posz,tag_sudu, tag_pinglv);
 
            }
            getClose();
            JOptionPane.showMessageDialog(jpan, "±í¸ñµ¼Èë³É¹¦£¡", "ÌáʾÐÅÏ¢",    JOptionPane.INFORMATION_MESSAGE);// µ¯³öÌáʾ¿ò
        }                                       
 
 
 
    }
 
    /**ÈËÔ±ÐÅÏ¢±í¸ñµ¼ÈëÊý¾Ý¿âµÄ·½·¨*/
    public void excelPersonToMysql(JPanel jpan) {    
 
        chooser.setFileFilter(filter);//Ìí¼ÓÎļþ¹ýÂËÆ÷
        option=chooser.showOpenDialog(jpan);//ÏÔʾѡÔñÎļþ¶Ô»°¿ò
        if(option==JFileChooser.APPROVE_OPTION) {//Èç¹ûÓû§Ñ¡ÔñµÄÊÇ¡°´ò¿ª¡±°´Å¥
            file=chooser.getSelectedFile();//»ñȡѡÖеÄÎļþ    
            num= getSheet(file).getLastRowNum();//»ñÈ¡µÚÒ»ÕÅ±íµ¥ÖеÄ×ÜÐÐÊý
            //±éÀúrow                
            for(int rowNum=1;rowNum <=num;rowNum++) {                    
                String tagids=String.valueOf(getSheet(file).getRow(rowNum).getCell(1)).trim();//±êÇ©ID
                String name=String.valueOf(getSheet(file).getRow(rowNum).getCell(2)).trim();//ÐÕÃû
                String bumen=String.valueOf(getSheet(file).getRow(rowNum).getCell(3)).trim();//²¿ÃÅ
                String sex=String.valueOf(getSheet(file).getRow(rowNum).getCell(4)).trim();//ÐÔ±ð
                String phone=String.valueOf(getSheet(file).getRow(rowNum).getCell(5)).trim();//µç»°
 
 
                if (tagids.length()<4){
                    ShowMessage.zidingyi("Ìí¼Óʧ°Ü,"+tagids+"±êÇ©Id³¤¶ÈСÓÚ4");
                }
                String tagid=tagids.substring(0,4);
 
                if(name.length()<2 || name.equals("null")) {
                    name="δ°ó¶¨";
                }
 
                if(bumen.length()<3 || bumen.equals("null")) {
                    bumen="ϵͳĬÈÏ";
                }
 
                if(sex.equals("")|| sex.equals("null")) {
                    sex="ÄÐ";
                }
 
                if(phone.length()<8 || phone.equals("null")) {
                    phone="***";
                }
 
                if(tagid.length()>3) {
                    if(Tag_Dell.addtag_person_excel_into(tagid, name, bumen, sex, phone)) {
                        // µ¯³öÌáʾ¿ò
                        ShowMessage.zidingyi(tagid+"µ¼ÈëÊý¾Ý¿â³É¹¦..."+GetNowTime.now());
                    }
                }
 
            }
            getClose();
 
        }                               
 
    }
 
    /**»ùÕ¾ÐÅÏ¢±í¸ñµ¼ÈëÊý¾Ý¿âµÄ·½·¨*/
    public void excelAnchorToMysql(JPanel jpan) {    
 
        chooser.setFileFilter(filter);//Ìí¼ÓÎļþ¹ýÂËÆ÷
        option=chooser.showOpenDialog(jpan);//ÏÔʾѡÔñÎļþ¶Ô»°¿ò
        if(option==JFileChooser.APPROVE_OPTION) {//Èç¹ûÓû§Ñ¡ÔñµÄÊÇ¡°´ò¿ª¡±°´Å¥
            file=chooser.getSelectedFile();//»ñȡѡÖеÄÎļþ    
            num= getSheet(file).getLastRowNum();//»ñÈ¡µÚÒ»ÕÅ±íµ¥ÖеÄ×ÜÐÐÊý
            //±éÀúrow                
            for(int rowNum=1;rowNum <=num;rowNum++) {    
                String anchorid=String.valueOf(getSheet(file).getRow(rowNum).getCell(1));//»ùÕ¾id                
                String POSX=String.valueOf(getSheet(file).getRow(rowNum).getCell(2));//»ùÕ¾X×ø±ê
                String POSY=String.valueOf(getSheet(file).getRow(rowNum).getCell(3));//»ùÕ¾Y×ø±ê
                String POSZ=String.valueOf(getSheet(file).getRow(rowNum).getCell(4));//»ùÕ¾Z×ø±ê
                String layer=String.valueOf(getSheet(file).getRow(rowNum).getCell(5));//»ùÕ¾ËùÔÚ²ã
                String anchormode=String.valueOf(getSheet(file).getRow(rowNum).getCell(6));//»ùվ״̬
                String anchorip=String.valueOf(getSheet(file).getRow(rowNum).getCell(7));//»ùÕ¾ipµØÖ·    
 
                if(!JugeNumber.isDigit(anchorid)) {                
                    ShowMessage.zidingyi_24(anchorid+"»ùÕ¾ID±ØÐë´¿Êý×ÖÇëÐ޸ģ¡");
                    return;
                }
 
                if(layer.equals("null")) {
                    layer="0";
                }
 
                if(POSX.equals("null")) {
                    POSX="0";
                }
 
                if(POSY.equals("null")) {
                    POSY="0";
                }
 
                if(POSY.equals("null")) {
                    POSZ="0";
                }
 
                if(anchorip.equals("null")) {
                    anchorip="";
                }
 
                if(Anchor_Dell.get_anchor(anchorid) ==null) {
 
                    String[]  ziduan= {"anchorid","POSX","POSY","POSZ","layer","zu",
                            "liangcheng","anchormode","anchorip","baoliu1","baoliu5","GreateTime"};
                    String[] zhi= {anchorid,POSX,POSY,POSZ,layer,"0",
                            "100000",anchormode,anchorip,"","0",GetNowTime.now()};
 
                    if(DatabaseManagement.insertfast("tb_achor", ziduan, zhi)) {    
                        AnchorManage.add_new_anchor_do(anchorid, POSX, POSY, POSZ, layer, "0", "100000", anchorip,"0", anchormode,"0");
                        ShowMessage.zidingyi(anchorid+"µ¼ÈëÊý¾Ý¿â³É¹¦..."+GetNowTime.now());
                    }
                }
 
            }
            ShowMessage.zidingyi_24("Êý¾Ýµ¼ÈëÍê±ÏÇëÖØÆôÈí¼þ");
            getClose();
            JOptionPane.showMessageDialog(jpan, "±í¸ñµ¼Èë³É¹¦£¡", "ÌáʾÐÅÏ¢",    JOptionPane.INFORMATION_MESSAGE);// µ¯³öÌáʾ¿ò
        }                               
 
    }
 
 
}